Java,List操作技巧
阿新 • • 發佈:2020-08-05
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