实际开发中,查询功能常常需要进行去重。
从网上找到了如下的方法。我使用的是
List<Seller> list3 = new ArrayList<>();
list1.addAll(list2);
for (Seller seller : list2) {
if(!list3.contains(seller)){
list3.add(seller);
}
}
转载来源:https://www.cnblogs.com/cainiao-Shun666/p/7911142.html
转了一圈,还是csdn上的东西。
list = list.stream().distinct().collect(Collectors.toList());这个方法是上面来源的吸氧羊与肥汰狼 提供的,jdk的新特性,没有实际使用过。
Java中List集合去除重复数据的方法
1. 循环list中的所有元素然后删除重复
public static List removeDuplicate(List list) { for ( int i = 0 ; i < list.size() - 1 ; i ++ ) { for ( int j = list.size() - 1 ; j > i; j -- ) { if (list.get(j).equals(list.get(i))) { list.remove(j); } } } return list; }
2. 通过HashSet踢除重复元素
public static List removeDuplicate(List list) { HashSet h = new HashSet(list); list.clear(); list.addAll(h); return list; }
3. 删除ArrayList中重复元素,保持顺序
// 删除ArrayList中重复元素,保持顺序 public static void removeDuplicateWithOrder(List list) { Set set = new HashSet(); List newList = new ArrayList(); for (Iterator iter = list.iterator(); iter.hasNext();) { Object element = iter.next(); if (set.add(element)) newList.add(element); } list.clear(); list.addAll(newList); System.out.println( " remove duplicate " + list); }
4.把list里的对象遍历一遍,用list.contain(),如果不存在就放入到另外一个list集合中
public static List removeDuplicate(List list){ List listTemp = new ArrayList(); for(int i=0;i<list.size();i++){ if(!listTemp.contains(list.get(i))){ listTemp.add(list.get(i)); } } return listTemp; }
转载:http://blog.csdn.net/u011728105/article/details/46594963