欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

java8如何用Stream查List对象某属性是否有重复

程序员文章站 2023-12-31 20:29:28
目录使用stream查list对象某属性是否有重复方法一:使用java8新特性stream进行list去重使用stream查list对象某属性是否有重复java8开发中,针对list对象集合,常需要判...

使用stream查list对象某属性是否有重复

java8开发中,针对list对象集合,常需要判断某个属性是否存在重复值。用stream流处理能方便的得到结果。

练习一下stream的一些用法

测试示例java代码

  @test
    public void t2() {
        list<user> list = new arraylist<>();
        user user1 = new user("zhangsan", "beijing", 30);
        user user2 = new user("zhangsan", "beijing", 40);
        user user3 = new user("lisi", "shanghai", 35);
        user user4 = new user("lisi", "shanghai", 28);
        user user5 = new user("lisim", "shanghai", 32);
        list.add(user1); list.add(user2);list.add(user3); list.add(user4);list.add(user5);
        system.out.println("原始数据:"+list);
        //判断姓名是否有重复,练习使用java8的stream方法
        //方法1. distinct, 直接比较大小,只知道是否有重复
        list<string> collect1 = list.stream().map(user::getname).distinct().collect(collectors.tolist());
        system.out.println(collect1.size()!=list.size()?"方法1-姓名有重复":"无重复");
        //方法2.用户姓名计数
        map<object, long> collect2 = list.stream().collect(
                collectors.groupingby( user::getname , collectors.counting()  )   );
        system.out.println("姓名重复计数情况:"+collect2);
        //筛出有重复的姓名
        list<object> collect3 = collect2.keyset().stream().
                filter(key -> collect2.get(key) > 1).collect(collectors.tolist());
        //可以知道有哪些姓名有重复
        system.out.println("方法2-重复的姓名 : "+collect3);
        //方法3,对重复的姓名保留计数
        list<map<string, long>> collect4 = collect2.keyset().stream().
                filter(key -> collect2.get(key) > 1).map(key -> {
            map<string, long> map = new hashmap<>();
            map.put((string) key, collect2.get(key));
            return map;
        }).collect(collectors.tolist());
        system.out.println("方法3-重复的姓名及计数:"+collect4);
    }

运行结果,方便验证是否是需要的样子。

原始数据:[user(name=zhangsan, address=beijing, age=30), user(name=zhangsan, address=beijing, age=40), user(name=lisi, address=shanghai, age=35), user(name=lisi, address=shanghai, age=28), user(name=lisim, address=shanghai, age=32)]
方法1-姓名有重复
姓名重复计数情况:{lisi=2, zhangsan=2, lisim=1}
方法2-重复的姓名 : [lisi, zhangsan]
方法3-重复的姓名及计数:[{lisi=2}, {zhangsan=2}]

list的五种去重方式

面试中经常被问到的list如何去重,一般是口述,不需要代码体现,这个时候,思维一定要清晰,可以罗列出集中去重的方法,以展现你对list数据结构,以及相关方法的掌握,体现你的java基础学的是否牢固

下面,我就将五种方法逐一展现

新建一个list数组:

list list = new arraylist(); 
list.add(26); 
list.add(39); 
list.add(39); 
list.add(39); 
list.add(39); 
list.add(5); 
list.add(40); 
list.add(39); 
list.add(25); 
system.out.println(list); 

方法一:使用java8新特性stream进行list去重

list newlist = list.stream().distinct().collect(collectors.tolist()); 
system.out.println(“java8新特性stream去重:”+newlist); 
list.add(39); 

方法二:双重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)); 
} 
} 
} 

上面的方法研究后,确实有点小问题,下面放上优化后的方法(不推荐使用,速度太慢)

        for (int i = 0; i < list.size(); i++) {
            for (int j = 0; j < list.size(); ) {
//                    system.out.println(i+"-"+list.get(i)+"-"+j+"!!!!"+list.get(j));
                if (i != j && list.get(i) == list.get(j)) {
//                    system.out.println(j+":"+list.get(j));
                    list.remove(j);
                } else {
                    j++;
                }
            }
        }
system.out.println(“双重for循环去重:”+list); 
list.add(39); 

方法三:set集合判断去重,不打乱顺序

set set1 = new hashset(); 
list newlist1 = new arraylist(); 
for (integer integer : list) { 
if(set1.add(integer)) { 
newlist1.add(integer); 
} 
} 
system.out.println(“set集合判断去重:”+list); 
list.add(39); 

方法四:遍历后判断赋给另一个list集合

list newlist2 = new arraylist(); 
for (integer integer : list) { 
if(!newlist2.contains(integer)){ 
newlist2.add(integer); 
} 
} 
system.out.println(“赋值新list去重:”+newlist2); 
list.add(39); 

方法五:set和list转换去重

set set2 = new hashset(); 
list newlist3 = new arraylist(); 
set2.addall(list); 
newlist3.addall(set2); 
system.out.println(“set和list转换去重:”+newlist3);

以上为个人经验,希望能给大家一个参考,也希望大家多多支持。

上一篇:

下一篇: