TreeSet的使用的一些记录
最近做项目需要对集合的内的对象通过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()); }); }
下一篇:
华为机试:尼科彻斯定理