初心者の質問: 整数の配列を値として格納するハッシュマップがあります。各値のキーは、2 つの整数 (座標) で構成されるオブジェクトです。
私の質問: オブジェクト (私の「キー」) 内の 2 つの座標に基づいて、ハッシュマップから値を取得するにはどうすればよいですか?
私のCoordsクラス(Eclipseから少し助けて):
public class Coords {
int x;
int y;
public Coords(int x, int y) {
super();
this.x = x;
this.y = y;
}
@Override
public int hashCode() {
final int prime = 31;
int result = 1;
result = prime * result + x;
result = prime * result + y;
return result;
}
@Override
public boolean equals(Object obj) {
if (this == obj)
return true;
if (obj == null)
return false;
if (getClass() != obj.getClass())
return false;
Coords other = (Coords) obj;
if (x != other.x)
return false;
if (y != other.y)
return false;
return true;
}
}
ハッシュマップの構築:
public class BuildMap {
public Coords coords;
public int[] someData = new int[4];
public Random random = new Random();
HashMap<Coords, int[]> map = new HashMap<Coords, int[]>();
public void buildHashMap() {
// coordinates from (0,0) to (31,31)
for (int i = 0; i < 32; i++) {
for (int j = 0; j < 32; j++) {
coords = new Coords(i, j);
// Every Coord gets a few random numbers
for (int k = 0; k < 4; k++) {
someData[k] = random.nextInt(8564);
}
map.put(coords, someData);
}
}
座標 12,13 の配列にアクセスしたい場合、どうすれば取得できますか? 反復が必要ですか (そうでないことを願っています。もちろん、100,000 以上の座標とクイック アクセスを追加したいと考えています)。
私はこれがある程度の行で機能することを望んでいました
int[] theValues = map.get(new Coords(12,13));
あなたが私を助けてくれることを願っています。前もって感謝します!