为什么循环keySetTreeMap并得到一个.containsKey == false?
for (Object thisObject : map.keySet()) {
if (!map.containsKey(thisObject)) {
System.out.println("This line should be never reached.");
}
}
Run Code Online (Sandbox Code Playgroud)
经过很多次,很多不同的迭代和调用此行被击中.A map.get(thisObject)会回来null.但调试显示密钥(相同的引用,值和散列)和实际值在地图中.地图很小(25个元素)TreeMap<Long, Double>
更新:
正如@rgettman theres 所猜测的那样Comparator,在构造TreeMap时使用了一个自定义排序(没有看到它,因为它是从另一个类构造的).这个比较器只是(我猜)从这里复制粘贴
改变Comparator:
public int compare(Object a, Object b) {
if((Double)base.get(a) > (Double)base.get(b)) {
return 1;
} else if((Double)base.get(a) == (Double)base.get(b)) {
return 0;
} else {
return -1;
}
}
Run Code Online (Sandbox Code Playgroud)
至
...
} else if(base.get(a).equals(base.get(b))) { …Run Code Online (Sandbox Code Playgroud) 为什么我不能设置Codename One的SpanLabel的字体?
SpanLabel title = new SpanLabel("SpanLabel");
title.getAllStyles().setFont(Font.createSystemFont(Font.FACE_SYSTEM, Font.STYLE_BOLD, Font.SIZE_LARGE));
Run Code Online (Sandbox Code Playgroud)
不行.