1.使用list的remove方法双重for循环暴力移除(不推荐使用)
for (int i = 0; i < list.size(); i++) {
for (int j = 0; j < list.size(); j++) {
if(i!=j&&list.get(i)==list.get(j)) {
list.remove(list.get(j));
}
}
}
2.使用Java8特性的stream进行去重
先使用stream方法将集合转换为流,然后distinct去重,最后再将stream流collect收集为list
List<Integer> newList = oldList.stream().distinct().collect(Collectors.toList());
3.使用list的contains方法
新建一个newList,循环遍历oldList,使用contains方法将不重复的数据添加到newList,然后再清空oldList,将newList的值添加到oldList中
List<String> newList = new ArrayList<String>(oldList.size());
for (String str : oldList) {
if (!newList.contains(str)) {
newList.add(str);
}
}
oldList.clear();
oldList.addAll(newList);
4.使用set集合的唯一性
将list元素放入set中,set本身具有去重功能,然后再将set转换为list。缺点是它会改变原来list元素的顺序,因为HashSet本身是无序的,而TreeSet排序也不是List元素的原有顺序。
(使用HashSet或者TreeSet)
//去重并排序的方法(如果是字符串,按字母表排序。如果是对象,按Comparable接口实现排序)
List<String> newList = new ArrayList<>(new TreeSet<>(oldList));
//简写的方法
List<String> newList = new ArrayList<>(new HashSet<>(oldList));