前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >list去重 distinct

list去重 distinct

作者头像
全栈程序员站长
发布2022-08-31 19:12:59
5740
发布2022-08-31 19:12:59
举报

大家好,又见面了,我是你们的朋友全栈君。

总结下。

1. 使用java8新特性stream进行List去重

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

2.双重for循环去重 (不推荐使用,速度太慢)

实际是使用list自身方法remove()方法。

for (int i = 0; i < list.size(); i++) { for (int j = 0; j < list.size(); ) { if (i != j && list.get(i) == list.get(j)) { list.remove(j); } else { j++; } } }

3.set集合判断去重

不打乱顺序

A // 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)); }

B Set set1 = new HashSet(); List newList1 = new ArrayList(); for (Integer integer : list) { if(set1.add(integer)) { newList1.add(integer); } }

打乱顺序

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

4.遍历后判断赋给另一个list集合

List newList2 = new ArrayList(); for (Integer integer : list) { if(!newList2.contains(integer)){ newList2.add(integer); } }

5.

Set set2 = new HashSet(); List newList3 = new ArrayList(); set2.addAll(list); newList3.addAll(set2); System.out.println(“set和list转换去重:”+newList3);

发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/142635.html原文链接:https://javaforall.cn

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2022年5月2,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档