废话不多说,直接上代码!
list.add("a");
list.add("a");
list.add("c");
list.add("b");
list.add("f");
list.add("b");
list.add("c");
list.add("d");
list.add("c");
```
#### 1.使用LinkedHashSet删除List中重复元素
```HashSet<String> integers = new HashSet<>(list);
System.out.println(integers);
输出:[a, c, b, f, d]```
#### 2.使用HashSet/Set删除List中重复元素
```Set<String> set new HashSet<>(list);
System.out.println(set);
输出:[a, b, c, d, f]
或者:
HashSet<String> hashSet = new HashSet<>(list);
System.out.println(hashSet);
输出:[a, b, c, d, f]```
#### 3.使用java8新特性stream进行List去重
```List<String> collect = list.stream().distinct().collect(Collectors.toList());
System.out.println(collect);
输出:[a, c, b, f, d]```
### 总结:
LinkedHashSet是在一个List删除重复数据的最佳方法,LinkedHashSet在内部完成两件事:
1.删除重复数据
2.同时使用链表维护元素的次序,**保持添加到其中的数据的顺序**
Set/HashSet利用set集合的元素不可重复性,删除数组中的重复元素,**但HashSet不能保证元素的排列顺序**,顺序有可能发生变化