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());
        });

    }
经验分享 程序员 微信小程序 职场和发展