在项目中看到一段代码:
return new ArrayList<>(new HashSet<LabelEnum>(list));
当时我的表情是这样的:
这把list作为构造参数创建新的集合来返回是要做什么,这里的list也是ArrayList集合,这样绕了一圈返回,恩,
想起一句话“存在即是合理”开始琢磨业务需要:list中的元素不能有重复。
那为什么不直接用HashSet呢?
因为这个list到时是要存入DTO中,所以尽量不修改原来的代码。使用list转换set再转回list,达到集合元素去重复的目的。
Set与List之间转化:
- List list = new ArrayList(set);
- Set set = new HashSet(list);
但是有一点,转换当中可能要丢失数据,尤其是从list转换到set的时候,因为set不能有重复数据
测试:
public static void main(String[] args) {
List<String> list = new ArrayList<>();
Collections.addAll(list, "haha", "xixi", "huihui", "haha", "aaa");//填充
System.out.println("list:" + list);
Set<String> set = new HashSet<>(list);//通过构造函数给set填充list中的数据,内部就是初始化后调用的addAll(Collection<T>)
// set.addAll(list);//或者用addAll(Collection<T>)方法给set填充,这时重复的数据"haha"将只存储第一个
System.out.println("set:" + set);
list.clear();//清空list,不然下次把set元素加入此list的时候是在原来的基础上追加元素的
list.addAll(set);//把set的内容填充给list
System.out.println("list:" + list);
}
结果:
list:[haha, xixi, huihui, haha, aaa] //说明list是有序的,可以存重复数据
set:[aaa, haha, xixi, huihui] //说明set是无序的,不可以存重复数据
list:[aaa, haha, xixi, huihui]