Java 中的 stream.distinct() 方法用于过滤掉流中的重复元素,确保生成的流仅包含唯一元素。它基于流中对象的 equals() 方法工作。
此方法是 java 8 中引入的 java stream api 的一部分,通常用于处理具有重复值的集合或数组。
示例 1:从字符串列表中删除重复项
想象一下你有一个名字列表,其中一些名字是重复的。您想要一个唯一名称的列表。
import java.util.list; import java.util.stream.collectors; public class main { public static void main(string[] args) { // list of names with duplicates list<string> names = list.of("alice", "bob", "alice", "charlie", "bob", "david"); // use stream.distinct() to remove duplicates list<string> uniquenames = names.stream() .distinct() .collect(collectors.tolist()); system.out.println(uniquenames); // output: [alice, bob, charlie, david] } }
工作原理:
立即学习“Java免费学习笔记(深入)”;
distinct() 方法比较每个名称并仅保留第一次出现的重复项。
示例 2:从数字列表中删除重复项
让我们列出存在重复的数字并仅提取唯一的数字。
import java.util.list; import java.util.stream.collectors; public class main { public static void main(string[] args) { // list of numbers with duplicates list<integer> numbers = list.of(1, 2, 3, 2, 4, 3, 5); // use stream.distinct() to remove duplicates list<integer> uniquenumbers = numbers.stream() .distinct() .collect(collectors.tolist()); system.out.println(uniquenumbers); // output: [1, 2, 3, 4, 5] } }
工作原理:
立即学习“Java免费学习笔记(深入)”;
使用数字的自然相等性进行比较(基于整数的 equals()),因此重复项会被过滤掉。
示例 3:使用简单对象
让我们创建一个 product 类并根据产品的 id 删除重复项。
代码:
import java.util.list; import java.util.objects; import java.util.stream.collectors; class product { private int id; private string name; public product(int id, string name) { this.id = id; this.name = name; } public int getid() { return id; } public string getname() { return name; } @override public boolean equals(object o) { if (this == o) return true; if (o == null || getclass() != o.getclass()) return false; product product = (product) o; return id == product.id; } @override public int hashcode() { return objects.hash(id); } @override public string tostring() { return "product{id=" + id + ", name='" + name + "'}"; } } public class main { public static void main(string[] args) { // list of products with duplicates (based on id) list<product> products = list.of( new product(1, "laptop"), new product(2, "tablet"), new product(1, "laptop"), // duplicate new product(3, "smartphone"), new product(2, "tablet") // duplicate ); // use stream.distinct() to remove duplicates list<product> uniqueproducts = products.stream() .distinct() .collect(collectors.tolist()); system.out.println(uniqueproducts); // output: // [product{id=1, name='laptop'}, product{id=2, name='tablet'}, product{id=3, name='smartphone'}] } }
说明:
相等性检查:重写 equals() 方法以确保 product 对象根据其 id 被视为相等。
去重:当distinct()遇到两个具有相同id的产品时,只保留第一个。
输出:您获得独特产品的列表。
简化理解
- 对于原始或简单对象(如整数、字符串):
distinct() 通过直接比较值来删除重复项。
示例:[1, 2, 2, 3] 变为 [1, 2, 3]。
- 对于自定义对象:
您需要为类实现 equals() 和 hashcode() 方法。
distinct() 使用这些方法来确定两个对象是否重复。
用例:过滤用户输入中的重复名称
想象一下,用户在表单中重复输入名称,并且您希望确保仅存储唯一的名称。
import java.util.ArrayList; import java.util.List; import java.util.stream.Collectors; public class Main { public static void main(String[] args) { // Simulate user input List<String> userInput = new ArrayList<>(); userInput.add("John"); userInput.add("Mary"); userInput.add("John"); // Duplicate userInput.add("Alice"); // Remove duplicates List<String> uniqueInput = userInput.stream() .distinct() .collect(Collectors.toList()); System.out.println(uniqueInput); // Output: [John, Mary, Alice] } }
这确保应用程序仅存储唯一的名称,而不需要手动检查重复项。
最后的收获:
distinct() 很简单:它从流中删除重复项。
对于基元或不可变类型:直接使用即可。
对于自定义对象:确保正确的 equals() 和 hashcode() 实现。
实用提示:用它来清理任何形式的重复数据(例如列表、用户输入、数据库结果)。