我尝试使用HashSet来存储我创建的一个类的对象,但显然相同的对象似乎有两个不同的散列,这就是为什么contains方法没有意识到该对象已经在HashSet中的原因。这会导致我的程序耗尽堆内存。
我不认为我做错了什么,但我还是想听听别人的意见。我以前也做过类似的操作,但都运行得很好,这使得这一点特别烦人。如果能帮上忙我会很感激的。
这是我的代码
move1 = new Move(t,s);
if(move1.hashCode()==new Move(t,s).hashCode())
System.out.println("match");
move2 = new Move(s,t);
moves.add(move1);
moves.add(move2);
if(moves.contains(new Move(t,s)))
System.out.println("match found");
下面是Move类:
public class Move {
private int move1;
private int move2;
Move(int m1, int m2)
{
move1 = m1;
move2 = m2;
}
public String toString()
{
return String.valueOf(move1)+" "+String.valueOf(move2);
}
}
下面是我得到的输出
Exception in thread "main" java.lang.OutOfMemoryError: Java heap space
at java.util.HashMap.addEntry(HashMap.java:797)
at java.util.HashMap.put(HashMap.java:431)
at java.util.HashSet.add(HashSet.java:194)
at makeMove.<init>(makeMove.java:33)
https://stackoverflow.com/questions/3692426
复制相似问题