记录一个出现的问题记录
示例:
Set<User> uniqueUsers = new LinkedHashSet<>();
for (int i = 0; i < 5; i++) {
List<User> objects = Arrays.asList(
new User(1, "Alice", 25),
new User(2, "Bob", 30),
new User(3, "Charlie", 35));
uniqueUsers.addAll(objects);
}
理论上来说这段代码没有问题 因为set查重 输出的数据也只有这三条
实际上输出的是
{1, "Alice", 25},
{2, "Bob", 30},
{3, "Charlie", 35},
{1, "Alice", 25},
{2, "Bob", 30},
{3, "Charlie", 35},
.....
上面的对象只是举个简单例子 实际上我的User是有很多值的不止这么一点
这就让我非常抓码 断点调试出来都是一模一样的数据 还是有重复的
后面网上找答案 可能是由以下原因导致的:
-
对象的等价性:在Java中,
Set
基于对象的equals()
方法来判断对象是否相等。如果两个User
对象的所有字段都相同,即使它们是不同的对象实例,它们也会被视为相等。因此,如果你在User
类中没有重写equals()
和hashCode()
方法,或者重写的方式不正确,可能会导致重复的值。 -
并发修改:如果你在迭代集合的同时修改了它(例如,添加或删除元素),这可能导致
ConcurrentModificationException
或意外的结果。尽管你的代码中没有直接修改集合 -
集合的大小问题:请确保
List<User> 返回的集合大小与预期一致,并且没有重复的元素。如果该方法返回的集合包含重复的元素,即使你已经使用了
Set`,重复的元素仍然会存在。 -
其他因素:可能还有其他原因导致重复的值,例如数据源的问题、其他部分的代码等。
后来我在User类中正确重写了equals和hashCode方法 问题得到解决 以此记录 避免下次再犯
public class User
// ... 其他属性和方法 ...
@Override
public boolean equals(Object o) {
if (this == o) return true;
if (o == null || getClass() != o.getClass()) return false;
User user = (User) o;
return Objects.equals(id, user.id) &&
Objects.equals(name, user.name);
}
@Override
public int hashCode() {
return Objects.hash(id, name);
}
}
问题总结:
- 确保在
User
类中正确重写equals()
和hashCode()
方法。 - 避免在迭代集合的同时修改它。
- 检查并确保
List<User>
数组返回的集合不包含重复的元素。