java是不是比较原始_如何比较两个对象,每个对象都包含Java中的原始类型和对象集合? - java...

我有两个如下的DTO对象,请注意,我在使用lombok来避免样板代码。

贸易协定

import lombok.Data;

import java.util.List;

@Data

public class DtoA {

private String name;

private String number;

private List aList;

}

企业对企业

import lombok.Data;

import java.util.List;

@Data

public class DtoB {

private String name;

private String phone;

private List bList;

}

我想比较两个对象的特定字段,所以我创建了一个适配器类型的对象,如下所示

DtoAdapter

import lombok.Data;

import java.util.List;

@Data

public class DtoAdapter {

private String nameText;

private List xList;

}

以下是我尝试进行比较的主要方法的Test类

由于aList和bList包含不同顺序的字符串,因此该比较失败。

我想比较列表的内容而不必担心它们的顺序。

测试

import junit.framework.Assert;

import java.util.ArrayList;

import java.util.List;

public class Test {

public static void main(String[] args) {

DtoA a = new DtoA();

List aList = new ArrayList<>();

aList.add("x"); aList.add("y"); aList.add("z");

a.setName("abc"); a.setNumber("123"); a.setAList(aList);

DtoB b = new DtoB();

List bList = new ArrayList<>();

bList.add("z"); bList.add("x"); bList.add("y");

b.setName("abc"); b.setPhone("123"); b.setBList(bList);

DtoAdapter a1 = new DtoAdapter();

a1.setNameText(a.getName()); a1.setXList(a.getAList());

DtoAdapter b1 = new DtoAdapter();

b1.setNameText(b.getName()); b1.setXList(b.getBList());

// comparision failing because of lists contains string in different orders

Assert.assertEquals(a1, b1);

}

}

注意:

我尝试编写compareTo(通过在DtoAdapter类中实现可比较的接口)

但是我无法使用compareTo方法编写两个列表的比较,如下所示

具有可比接口的DtoAdapter

import lombok.Data;

import java.util.List;

@Data

public class DtoAdapter implements Comparable{

private String nameText;

private List xList;

@Override

public int compareTo(DtoAdapter o) {

return this.getNameText().compareTo(o.getNameText());

// how to compare this.getXList() and o.getXList() with compareTo?

}

}

java参考方案

您期待的不是扩展Comparable而是扩展类的equals实现(当然还有hashcode)。

@Override

public boolean equals(Object o) {

if (this == o) return true;

if (o == null || getClass() != o.getClass()) return false;

DtoAdapter that = (DtoAdapter) o;

// following line of code specifically

return Objects.equals(nameText, that.nameText) &&

that.getXList().containsAll(xList) && xList.containsAll(that.getXList());

}

除了Comparable的文档之外,该接口主要用于对元素进行排序,而不用于相等性比较:

该接口对每个类的对象强加了总排序

实现它。此排序称为类的

自然排序,并且该类的compareTo方法称为

其自然的比较方法。

Java-固定大小的列表与指定初始容量的列表之间的差异 - java

我在理解这一点上遇到了问题。当我们做 List list = Arrays.asList(array); 我们不能在该列表上使用添加,删除之类的方法。我知道Arrays.asList()返回固定大小的列表。我不明白的是,如果我们创建一个具有指定初始容量的列表,例如List list2 = new A…java:继承 - java

有哪些替代继承的方法? java大神给出的解决方案 有效的Java:偏重于继承而不是继承。 (这实际上也来自“四人帮”)。他提出的理由是,如果扩展类未明确设计为继承,则继承会引起很多不正常的副作用。例如,对super.someMethod()的任何调用都可以引导您通过未知代码的意外路径。取而代之的是,持有对本来应该扩展的类的引用,然后委托给它。这是与Eric…Java-如何将此字符串转换为日期? - java

我从服务器收到此消息,我不明白T和Z的含义,2012-08-24T09:59:59Z将此字符串转换为Date对象的正确SimpleDateFormat模式是什么? java大神给出的解决方案 这是ISO 8601标准。您可以使用SimpleDateFormat simpleFormat = new SimpleDateFormat("yyyy-MM…在Map中,如果我们使用现有键进行修改,则不会获得ConcurrentModificationException - java

我有以下代码,我希望从情况2的情况下抛出ConcurrentModificationException,但它运行成功。据我所知,如果我对地图中的单个键执行相同的操作,则不会抛出异常,因为here但是当我重现这种具有两个案例的多个密钥的场景时,通过新密钥修改。通过现有密钥进行修改。情况1: Map mp = new H…从方法返回数组-Java - java

private static Coordinate[] getCircleCoordintaes() { Coordinate coordinates[] = {new Coordinate(0, 0)}; return coordinates; } 以上程序工作正常。在上面的程序中,返回的坐标数组首先初始化了数组使用这条线Coordinate coordi…

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值