所以我试图循环并将一组坐标存储到带有整数键的hashmap中。但是,hashmap似乎将最后一对坐标映射到每个键,这样当我遍历并获得每一对时,它们都是相同的。代码如下,任何帮助都会很棒!谢谢!
public HashMap<Integer,int[]> tiles;
public Board()
{
setPreferredSize(new Dimension(600, 600));
tiles = new HashMap<Integer,int[]>();
setTiles();
}
public void setTiles() {
int[] coords = { 525, 525 };
Integer square;
for (square=1;square<=9;square++) {
System.out.println(square+": "+coords[0]+",, "+coords[1]);
tiles.put(square,coords);
int[] coord = tiles.get(square);
System.out.println(square+": "+coord[0]+"; "+coord[1]);
coords[0] = coords[0] - 50;
}
tiles.put(square,coords);
for (square=11;square<=19;square++) {
System.out.println(square+": "+coords[0]+",, "+coords[1]);
tiles.put(square,coords);
int[] coord = tiles.get(square);
System.out.println(square+": "+coord[0]+"; "+coord[1]);
coords[1] = coords[1] - 50;
}
tiles.put(square,coords);
for (square=21;square<=29;square++) {
System.out.println(square+": "+coords[0]+",, "+coords[1]);
tiles.put(square,coords);
int[] coord = tiles.get(square);
System.out.println(square+": "+coord[0]+"; "+coord[1]);
coords[0] = coords[0] + 50;
}
tiles.put(square,coords);
for (square=31;square<=39;square++) {
System.out.println(square+": "+coords[0]+",, "+coords[1]);
tiles.put(square,coords);
int[] coord = tiles.get(square);
System.out.println(square+": "+coord[0]+"; "+coord[1]);
coords[1] = coords[1] + 50;
}
tiles.put(square,coords);
for (square = 1;square<=40;square++) {
int[] coord = tiles.get(square);
System.out.println(square+": "+coord[0]+"/ "+coord[1]);
}
}
答案 0 :(得分:3)
您正在为所有键重用相同的数组实例。每次put
数组的副本最好。例如:
tiles.put(square, Arrays.copyOf(coords, 2));
而不是
tiles.put(square, coords);
答案 1 :(得分:0)
您将同一int[]
反复放入HashMap
。因此,HashMap
的所有键都可以看到最后一次修改。
put
操作不会将值的副本放入地图中,而是放置对该对象的引用。您有很多对同一int[]
的引用。
相反,在添加数组后,将新数组分配给square
,以便对put
中的单独数组的引用为HashMap
。