使用LinkedHashSet删除arraylist中的重复数据(有序) LinkedHashSet是在一个ArrayList删除重复数据的最佳方法。LinkedHashSet在内部完成两件事: 删除重复数据 保持添加到其中的数据的顺序 ListStrin
使用LinkedHashSet删除arraylist中的重复数据(有序)
LinkedHashSet是在一个ArrayList删除重复数据的最佳方法。LinkedHashSet在内部完成两件事:
- 删除重复数据
- 保持添加到其中的数据的顺序
List<String> words= Arrays.asList("a","b","b","c","c","d"); HashSet<String> set=new LinkedHashSet<>(words); for(String word:set){ System.out.println(word); }
使用HashSet去重(无序)
//去掉List集合中重复的元素 List<String> words= Arrays.asList("a","b","b","c","c","d"); //方案一: for(String word:words){ set.add(word); } for(String word:set){ System.out.println(word); }
使用java8新特性stream进行List去重
要从arraylist中删除重复项,我们也可以使用java 8 stream api。使用steam的distinct()方法返回一个由不同数据组成的流,通过对象的equals()方法进行比较。
收集所有区域数据List使用Collectors.toList()。
Java程序,用于在不使用Set的情况下从java中的arraylist中删除重复项。
List<String> words= Arrays.asList("a","b","b","c","c","d"); words.stream().distinct().collect(Collectors.toList()).forEach(System.out::println);
利用List的contains方法循环遍历
List<String> list= new ArrayList<>(); for (String s:words) { if (!list.contains(s)) { list.add(s); } }
注:当数据元素是实体类时,需要额外重写equals()和hashCode()方法。
例如:
以学号为依据判断重复
public class Student { String id; String name; int age; public Student(String id, String name, int age) { this.id = id; this.name = name; this.age = age; } @Override public boolean equals(Object o) { if (this == o) return true; if (o == null || getClass() != o.getClass()) return false; Student student = (Student) o; return Objects.equals(id, student.id); } @Override public int hashCode() { return id != null ? id.hashCode() : 0; } @Override public String toString() { return "Student{" + "id='" + id + '\'' + ", name='" + name + '\'' + ", age=" + age + '}'; } }
到此这篇关于java List去掉重复元素的几种方式(小结)的文章就介绍到这了,更多相关java List去掉重复元素内容请搜索易盾网络以前的文章或继续浏览下面的相关文章希望大家以后多多支持易盾网络!