I am keeping Node objects in a TreeSet:
public TreeSet<Node> viewNodes = new TreeSet<Node>();
Node looks like this:
public class Node implements Comparable<Node>{
private long nodeID;
...
public long getID() {
return nodeID;
}
@Override
public int compareTo(Node n) {
System.out.println("comparing: " +this + " with " + n + " -- " + new Long(nodeID).compareTo(n.getID()));
return new Long(nodeID).compareTo(n.getID());
}
@Override
public boolean equals(Object o){
if(o instanceof Node){
System.out.println((compareTo((Node)o) == 0));
return compareTo((Node)o) == 0;
}
return false;
}
@Override
public int hashCode(){
return new Long(nodeID).hashCode();
}
}
However, when I try to remove nodes, they do not get removed, and the TreeSet thinks they are not in the set!!
Remove code:
System.out.println("removing " + node);
System.out.println("viewNodes: " + viewNodes);
System.out.println("contains node?: " + viewNodes.contains(node));
viewNodes.remove(node);
System.out.println("now viewNodes looks like: " +viewNodes);
Output:
removing 5
viewNodes: [5, 4, 3, 2, 1]
comparing: 5 with 2 -- 1
comparing: 5 with 1 -- 1
contains node?: false
comparing: 5 with 2 -- 1
comparing: 5 with 1 -- 1
now viewNodes looks like: [5, 4, 3, 2, 1]
Why is this? I've implemented Comparable, shouldn't that be it?