Java,List操作技巧

Java List 操作技巧

去重

借助Set去重 , 效率要好一些 , 算是以空间换时间

List ori = Arrays.asList(2,1,4,5,3,2,1);
Set unique = new HashSet(ori);
List unique_list = new ArrayList(unique);

排序

自身排序

如果是基础类型, JDK里都已经实现了排序, 直接使用就可以了.

List<Integer> ori = Arrays.asList(2,1,4,5,3); //源顺序List
ori.sort(new Comparator<Integer>() {
            @Override
            public int compare(Integer o1, Integer o2) {
                return o1.compare(o2); //正序
                //return o2.compare(o1); //倒序
            }
        }); 
--------
//简洁方式
ori.sort(Integer::compareTo); //正序
ori.sort(Comparator.reverseOrder()); //倒序

参考排序

给定一个顺序 , 参考这个顺序排序

例如: 有个顺序 2,1,4,5,3, 要列表按这个顺序排列

List<Integer> ori = Arrays.asList(2,1,4,5,3); //源顺序List
List<Integer> target = Arrays.asList(4,5,3,1,2); //要排序的List
target.sort(new Comparator<Integer>() {
            @Override
            public int compare(Integer o1, Integer o2) {
                return Integer.compare(ori.indexOf(o1),ori.indexOf(o2));
            }
        });

System.out.println(target); // 结果 2,1,4,5,3

Java 8 以上的话, 还可以用简单和表达式 , 省不少代码

List<Integer> ori = Arrays.asList(2,1,4,5,3); //源顺序List
List<Integer> target = Arrays.asList(4,5,3,1,2); //要排序的List
target.sort(Comparator.comparingInt(s -> ori.indexOf(s)));

System.out.println(target); // 结果 2,1,4,5,3

当然也可以是按Bean的字段排序 .

List<Integer> ori = Arrays.asList(2,1,4,5,3); //源顺序List
List<ID> target = Arrays.asList(4,5,3,1,2); //要排序的List
target.sort(Comparator.comparingInt(s -> ori.indexOf(s.getId())));

System.out.println(target); // 结果 2,1,4,5,3

指定元素排到最前或最后

同样的顺序 2,1,4,5,3 , 想把 4 拓到最前面 .

List<Integer> ori = Arrays.asList(2,1,4,5,3); //源顺序List
ori.sort(((o1, o2) -> o1 == 4L ? 1 : -1); // 4 往前移, 其他都往后移

如果文章有帮助到您,请点个赞,您的反馈会让我感到文章是有价值的

posted @ 2020-08-05 11:17  孙行者、  阅读(188)  评论(0编辑  收藏  举报