Java 8 Stream.distinct() 列表去重示例

Java 8 Stream.distinct() 列表去重示例Java8Stream distinct 示例 nbsp nbsp nbsp nbsp nbsp 在这篇文章里 我们将提供 Java8Streamd 示例 nbsp distinct 返回由该流的不同元素组成的流 distinct 是 Stream 接口的方法 distinct 使用 hashCode 和 equals 方法来获取不同的元素 因此 我们的类必须实现 hashCode 和 equals 方法 如果 dist

Java 8 Stream.distinct() 示例
 

    在这篇文章里,我们将提供Java8 Stream distinct()示例。 distinct()返回由该流的不同元素组成的流distinct()是Stream接口的方法。distinct()使用hashCode()和equals()方法来获取不同的元素。因此,我们的类必须实现hashCode()和equals()方法。如果distinct()正在处理有序流,那么对于重复元素,将保留以遭遇顺序首先出现的元素,并且以这种方式选择不同元素是稳定的。在无序流的情况下,不同元素的选择不一定是稳定的是可以改变的。distinct()执行有状态的中间操作。在有序流的并行流的情况下,保持distinct()的稳定性是需要很高的代价的,因为它需要大量的缓冲开销。如果我们不需要保持遭遇顺序的一致性,那么我们应该可以使用通过BaseStream.unordered()方法实现的无序流。

1. Stream.distinct()

distinct()方法的声明如下:
Stream 
   
     distinct() 
   

它是Stream接口的方法。在此示例中,我们有一个包含重复元素的字符串数据类型列表

DistinctSimpleDemo.java

package com.concretepage; import java.util.Arrays; import java.util.List; import java.util.stream.Collectors; public class DistinctSimpleDemo { public static void main(String[] args) { List 
   
     list = Arrays.asList("AA", "BB", "CC", "BB", "CC", "AA", "AA"); long l = list.stream().distinct().count(); System.out.println("No. of distinct elements:"+l); String output = list.stream().distinct().collect(Collectors.joining(",")); System.out.println(output); } } 
   

Output
 

No. of distinct elements:3 AA,BB,CC 

2. Stream.distinct() with List of Objects

在此示例中,我们有一个Book对象列表。 为了对列表进行去重,该类将重写hashCode()和equals()。

Book.java

package com.concretepage; public class Book { private String name; private int price; public Book(String name, int price) { this.name = name; this.price = price; } public String getName() { return name; } public int getPrice() { return price; } @Override public boolean equals(final Object obj) { if (obj == null) { return false; } final Book book = (Book) obj; if (this == book) { return true; } else { return (this.name.equals(book.name) && this.price == book.price); } } @Override public int hashCode() { int hashno = 7; hashno = 13 * hashno + (name == null ? 0 : name.hashCode()); return hashno; } } 

DistinctWithUserObjects.java

package com.concretepage; import java.util.ArrayList; import java.util.List; public class DistinctWithUserObjects { public static void main(String[] args) { List 
   
     list = new ArrayList<>(); { list.add(new Book("Core Java", 200)); list.add(new Book("Core Java", 200)); list.add(new Book("Learning Freemarker", 150)); list.add(new Book("Spring MVC", 300)); list.add(new Book("Spring MVC", 300)); } long l = list.stream().distinct().count(); System.out.println("No. of distinct books:"+l); list.stream().distinct().forEach(b -> System.out.println(b.getName()+ "," + b.getPrice())); } } 
   

Output
 


No. of distinct books:3 Core Java,200 Learning Freemarker,150 Spring MVC,300 

3. Distinct by Property

distinct()不提供按照属性对对象列表进行去重的直接实现。它是基于hashCode()和equals()工作的。如果我们想要按照对象的属性,对对象列表进行去重,我们可以通过其它方法来实现。如下代码段所示:

static 
    
      Predicate 
     
       distinctByKey(Function 
       keyExtractor) { Map 
      
        seen = new ConcurrentHashMap<>(); return t -> seen.putIfAbsent(keyExtractor.apply(t), Boolean.TRUE) == null; } 
       
      
    

上面的方法可以被Stream接口的 filter()接收为参数,如下所示:



list.stream().filter(distinctByKey(b -> b.getName())); 

distinctByKey()方法返回一个使用ConcurrentHashMap 来维护先前所见状态的 Predicate 实例,如下是一个完整的使用对象属性来进行去重的示例。

DistinctByProperty.java

package com.concretepage; import java.util.ArrayList; import java.util.List; import java.util.Map; import java.util.concurrent.ConcurrentHashMap; import java.util.function.Function; import java.util.function.Predicate; public class DistinctByProperty { public static void main(String[] args) { List 
    
      list = new ArrayList<>(); { list.add(new Book("Core Java", 200)); list.add(new Book("Core Java", 300)); list.add(new Book("Learning Freemarker", 150)); list.add(new Book("Spring MVC", 200)); list.add(new Book("Hibernate", 300)); } list.stream().filter(distinctByKey(b -> b.getName())) .forEach(b -> System.out.println(b.getName()+ "," + b.getPrice())); } private static 
     
       Predicate 
      
        distinctByKey(Function 
        keyExtractor) { Map 
       
         seen = new ConcurrentHashMap<>(); return t -> seen.putIfAbsent(keyExtractor.apply(t), Boolean.TRUE) == null; } } 
        
       
      
    

Output
 


Core Java,200 Learning Freemarker,150 Spring MVC,200 Hibernate,300 

from : 
https://www.concretepage.com/java/jdk-8/java-8-distinct-example


版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

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

(0)
上一篇 2026年3月19日 上午10:30
下一篇 2026年3月19日 上午10:30


相关推荐

  • Linux 防火墙设置指定 IP 访问

    Linux 防火墙设置指定 IP 访问1 修改防火墙配置 vi nbsp etc sysconfig iptables nbsp nbsp 添加以下内容 AINPUT ieth0 s192 168 0 1 ptcp jACCEPT nbsp AINPUT ieth0 s192 168 0 2 ptcp jACCEPT AINPUT ieth0 s192 168 0 3 ptcp jACCEPT AINPUT

    2025年7月15日
    6
  • redis 命令手册

    redis 命令手册redis 命令手册

    2026年3月20日
    2
  • 快速搭建自己的直播服务器,完成属于你的直播服务。

    快速搭建自己的直播服务器,完成属于你的直播服务。通过本文您能学到以下内容:1、动手搭建直播服务器,完成一次对移动端支持的直播。2、使用OBS推流。3、使用html5网页播放m3u8流媒体文件。一、动手搭建流媒体服务器这里我们选用开源srs流媒体服务器[https://github.com/ossrs/srs],有兴趣的同学也可选用[AdobeMediaServer5],原理都是一样的。安装方法在[https://…

    2022年6月11日
    135
  • BurpSuit暴力激活成功教程密码

    BurpSuit暴力激活成功教程密码暴力激活成功教程原理暴力激活成功教程是用户自定义字典文件中的内容与验证程序交互,从而在枚举过程中得到正确数据案例:激活成功教程用户名、密码激活成功教程验证码-之前四位数的手机验证码在未进行任何防护措施,导致被枚举出来暴力激活成功教程的基础应用程序或服务器未进行限制具有内容涵盖全方面的字典文件暴力激活成功教程方式根据激活成功教程的验证码内容是否处于服务状态将暴力激活成功教程分为以下两类:1.在线激活成功教程2.离线激活成功教程无论是在线还是离线是否可以…

    2022年8月22日
    14
  • Linux下的FTP服务器搭建

    Linux下的FTP服务器搭建参考文章 https help aliyun com document detail 60152 html spm 5176 22414175 sslink 1 1ea4617cAVoi 一 FTP 服务器配置第一步 准备远程服务器这里使用阿里云轻量级应用服务器 本服务器是 Ubuntu 系统 由于之前项目用到了 npm 包管理工具 这里就基于此进行配置 第二步 安装 vsftpd FTP 服务器管理软件 2 1 连接服务器之后 通过 putty 软件进行命令行连接控制 输入 npminstallyu

    2026年3月19日
    2
  • java 运行jar包命令_用java –jar 命令运行Jar包

    java 运行jar包命令_用java –jar 命令运行Jar包摘要这个技巧阐明了如何不直接处理清单文件而将一个不能运行 jar 包转换成一个可以执行的 jar 包 学会如何写一段转换 jar 包的程序 将你的 jar 包转换成你能使用 java jar 命令运行 jar 包或象在 windows 系统上那样通过双击来运行 jar 包 你可以很容易地将一个应用的所有的类和资源打包到一个 jar 文件中去 事实上 这只是打包的一个原因 另一个原因是让用户很容易地执行包中的应用 那么在 java 的

    2026年3月19日
    2

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号