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 往前移, 其他都往後移

如果文章有幫助到您,請點個贊,您的反饋會讓我感到文章是有價值的

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章