List数据去重的五种有效方法

时间:2025-03-10 13:46:24

目录

1:使用java8新特性stream进行List去重 (distinct()方法)

2,借助Set的特性进行去重(set和list转换去重 )

3,遍历List集合,将元素添加到另一个List集合中

4,利用set集合特性保持顺序一致去重

5,使用list自身方法remove()–>不推荐


1:使用java8新特性stream进行List去重 (distinct()方法

public static List<String> delRepeat(List<String> list) {
     List<String> myList = ().distinct().collect(());
	 return myList ;
}

2,借助Set的特性进行去重(set和list转换去重 

 	/**
     * 去除重复数据
     * 由于Set的无序性,不会保持原来顺序
     * @param list
     */
    public static List<String> list distinct(List<String> list) {
        final boolean sta = null != list && () > 0;
        List doubleList= new ArrayList();
        if (sta) {
            Set set = new HashSet();
            (list);
            (set);
        }
        return doubleList;
    }

3,遍历List集合,将元素添加到另一个List集合中

// 遍历后判断赋给另一个list集合,保持原来顺序
public static List<String> delRepeat(List<String> list) {
	  List<String> listNew = new ArrayList<String>();
	  for (String str : list) {
	       if (!(str)) {
	           (str);
	       }
	   }
	  return listNew ;
}

4,利用set集合特性保持顺序一致去重

// Set去重并保持原先顺序的两种方法
   public static void delRepeat(List<String> list) {
   	   //方法一
       List<String> listNew = new ArrayList<String>(new TreeSet<String>(list));
       //方法二
       List<String> listNew2 = new ArrayList<String>(new LinkedHashSet<String>(list));
   }

5,使用list自身方法remove()–>不推荐

    /**
     * 去除重复数据(一般不推荐)
     * 类似于冒泡排序思想
     * @param list
     */
  public static List<Map<String, Object>> distinct(List<Map<String, Object>> list) {
        if (null != list && () > 0) {
        //循环list集合
            for  ( int  i  =   0 ; i  <  ()  -   1 ; i ++ )  {
                for  ( int  j  =  ()  -   1 ; j  >  i; j -- )  {
                	// 这里是对象的比较,如果去重条件不一样,在这里修改即可
                    if  ((j).equals((i)))  {
                        (j);
                    }
                }
            }
        }
        //得到最新移除重复元素的list
        return list;
    }

————————————————
参考学习链接:/yihuaiyan/article/details/94719541