检查两个java对象的Deep Equal的最快捷有效的方法是什么?

时间:2015-04-17 09:42:48

标签: java deepequals

我有两个java对象,byte[]字段的大小为数百万。检查这些java对象的 Deep Equal 的最快捷有效的方法是什么?

示例实体:

@Entity
public class NormalBook
{

  @Id
  private String bookId;

  @Column
  private String title;

  @Column
  private byte[] pdfFile;

  //setters and getters

  }
  

注意:我正在为ORM工具这样做,基本上我正在检查一个对象   (处于托管状态),Persistence中存在一个对象   上下文。

3 个答案:

答案 0 :(得分:2)

覆盖equals()或者使用*辅助方法(错误选项!)并分5步执行:

1. Check for *not null*.
2. Check for same *type*.
3. Check for *size of byte[]*.
4. Check for `==` (*reference equality* of byte[]) 
5. Start comparing byte values 

答案 1 :(得分:0)

在对象类的equals()定义中使用以下内容:

java.util.Arrays.equals(bs1, bs2)

您可能还想先检查它们是否是相同的数组(实例)。虽然这种方法无论如何都可能做到这一点。

例如(并对包含数组的类做出一些假设):

public boolean equals(Object obj) {
    if(this == obj)
        return true;
    if(!(obj instanceof MyObject)) // covers case where obj null, too.
        return false;
    return Arrays.equals(this.bytes, ((MyObject)obj).bytes);
}

如果您的班级中还有其他字段,则equals()也应考虑这些字段。

(如果您可以提供有关阵列中存储的数据类型的更多信息,可能会有更好的答案。)

答案 2 :(得分:0)

如果您的班级有像byte[]这样的字段,您可以使用以下内容:

public class MyClass {


    byte[] a;

    public boolean equals(Object obj) {
        if (this == obj)
            return true;
        if (obj == null)
            return false;
        if (getClass() != obj.getClass())
            return false;
        MyClass other = (MyClass) obj;
        if (!Arrays.equals(a, other.a))
            return false;
        return true;
    }


}

如果您关注效果并且可以确保唯一hascode (这一点很重要hascode需要unique),那么您只需比较hascode。