最近做项目需要对集合的内的对象通过v1值进行排序,而且还会对结合添加新对象。一开始就使用了TreeSet,初始化时就用比较器来对结合内对象进行排序规定。
结果后期对象的v1值还会变化,然后忘记了对TreeSet进行重排序,结果出错了。之前想当然的觉得TreeSet能够在对象值变化时自动再帮我排序一次的,看来想得太天真了。总之这边记录下长点记性。
@Test
public void treeSetTest(){
Platform p1=new Platform(1);
Platform p2=new Platform(2);
Platform p3=new Platform(3);
p1.setV1(5.0);
p2.setV1(3.0);
p3.setV1(4.0);
TreeSet<Platform> treeSet = new TreeSet<Platform>((o1,o2)->(int)(o1.getV1()-o2.getV1()));
treeSet.add(p1);
treeSet.add(p2);
treeSet.add(p3);
treeSet.forEach(o1 -> {
System.out.println(o1.getId()+": v1="+o1.getV1());
});
p2.setV1(6.0);
p3.setV1(7.0);
System.out.println("+++++++++++++++++");
treeSet.forEach(o1 -> {
System.out.println(o1.getId()+": v1="+o1.getV1());
});
}