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 往前移, 其他都往后移
如果文章有帮助到您,请点个赞,您的反馈会让我感到文章是有价值的