合并两个对象 java_在Java中合并两个对象列表8

如果要实现equals和hashCode,那么这个方法就在Parent类中.在该类中添加类似的方法

@Override

public int hashCode() {

return Objects.hash(getAttrib1(), getAttrib2(), getAttrib3(),

// …

getAttrib19(), getAttrib20());

}

@Override

public boolean equals(Object obj) {

if(this==obj) return true;

if(!(obj instanceof Parent)) return false;

Parent p=(Parent) obj;

return Objects.equals(getAttrib1(), p.getAttrib1())

&& Objects.equals(getAttrib2(), p.getAttrib2())

&& Objects.equals(getAttrib3(), p.getAttrib3())

// …

&& Objects.equals(getAttrib19(), p.getAttrib19())

&& Objects.equals(getAttrib20(), p.getAttrib20());

}

如果你这样做了,在Stream< Parent>上调用distinct()会自动做正确的事情.

如果你不想(或不能)改变班级的父母,那么没有任何授权机制来平等,但是你可以采取订单,因为它有一个授权机制:

Comparator c=Comparator.comparing(Parent::getAttrib1)

.thenComparing(Parent::getAttrib2)

.thenComparing(Parent::getAttrib3)

// …

.thenComparing(Parent::getAttrib19)

.thenComparing(Parent::getAttrib20);

这定义了一个基于属性的顺序.它要求属性本身的类型是可比较的.如果你有这样的定义,可以使用它来实现基于该比较器的distinct()的等价物:

List result = Stream.concat(list1.stream(), list2.stream())

.filter(new TreeSet<>(c)::add)

.collect(Collectors.toList());

还有一个线程安全的变体,以防您想要使用并行流:

List result = Stream.concat(list1.stream(), list2.stream())

.filter(new ConcurrentSkipListSet<>(c)::add)

.collect(Collectors.toList());

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值