List和Set之间的转换:达到集合元素去重复

来源:互联网 发布:中央电视台网络直播 编辑:程序博客网 时间:2024/05/20 05:54

在项目中看到一段代码:

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]
原创粉丝点击