1. 程式人生 > 實用技巧 >Java,List操作技巧

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.stream().sorted(); //正序
ori.stream().sorted(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

指定元素排到最前或最後