这篇文章主要介绍了java List去掉重复元素的几种方式,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
使用LinkedHashSet删除arraylist中的重复数据(有序)
LinkedHashSet是在一个ArrayList删除重复数据的最佳方法。LinkedHashSet在内部完成两件事:
删除重复数据
保持添加到其中的数据的顺序
1
2
3
4
5
List words= Arrays.asList("a","b","b","c","c","d");
HashSet set=new LinkedHashSet<>(words);
for(String word:set){
System.out.println(word);
}
使用HashSet去重(无序)
1
2
3
4
5
6
7
8
9
//去掉List集合中重复的元素
List 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中删除重复项。
1
2
List words= Arrays.asList("a","b","b","c","c","d");
words.stream().distinct().collect(Collectors.toList()).forEach(System.out::println);
利用List的contains方法循环遍历
1
2
3
4
5
6
List list=new ArrayList<>();
for (String s:words) {
if (!list.contains(s)) {
list.add(s);
}
}
注:当数据元素是实体类时,需要额外重写equals()和hashCode()方法。
例如:
以学号为依据判断重复
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
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去掉重复元素的几种方式(小结)的文章就介绍到这了