public class EqualsBuilder extends Object implements Builder<Boolean>
Object.equals(Object) 方法的构建器
两个对象equals必须保证hashCode值相等,hashCode值相等不能保证一定equals
使用方法如下:
public boolean equals(Object obj) {
if (obj == null) { return false; }
if (obj == this) { return true; }
if (obj.getClass() != getClass()) {
return false;
}
MyClass rhs = (MyClass) obj;
return new EqualsBuilder()
.appendSuper(super.equals(obj))
.append(field1, rhs.field1)
.append(field2, rhs.field2)
.append(field3, rhs.field3)
.isEquals();
}
我们也可以通过反射判断所有字段是否equals:
public boolean equals(Object obj) {
return EqualsBuilder.reflectionEquals(this, obj);
}
| 构造器和说明 |
|---|
EqualsBuilder()
构造,初始状态值为true
|
| 限定符和类型 | 方法和说明 |
|---|---|
EqualsBuilder |
append(boolean[] lhs,
boolean[] rhs)
Deep comparison of array of
boolean. |
EqualsBuilder |
append(boolean lhs,
boolean rhs)
Test if two
booleanss are equal. |
EqualsBuilder |
append(byte[] lhs,
byte[] rhs)
Deep comparison of array of
byte. |
EqualsBuilder |
append(byte lhs,
byte rhs)
Test if two
bytes are equal. |
EqualsBuilder |
append(char[] lhs,
char[] rhs)
Deep comparison of array of
char. |
EqualsBuilder |
append(char lhs,
char rhs)
Test if two
chars are equal. |
EqualsBuilder |
append(double[] lhs,
double[] rhs)
Deep comparison of array of
double. |
EqualsBuilder |
append(double lhs,
double rhs)
Test if two
doubles are equal by testing that the pattern of bits returned by
doubleToLong are equal. |
EqualsBuilder |
append(float[] lhs,
float[] rhs)
Deep comparison of array of
float. |
EqualsBuilder |
append(float lhs,
float rhs)
Test if two
floats are equal byt testing that the pattern of bits returned by
doubleToLong are equal. |
EqualsBuilder |
append(int[] lhs,
int[] rhs)
Deep comparison of array of
int. |
EqualsBuilder |
append(int lhs,
int rhs)
Test if two
ints are equal. |
EqualsBuilder |
append(long[] lhs,
long[] rhs)
Deep comparison of array of
long. |
EqualsBuilder |
append(long lhs,
long rhs)
Test if two
long s are equal. |
EqualsBuilder |
append(Object[] lhs,
Object[] rhs)
Performs a deep comparison of two
Object arrays. |
EqualsBuilder |
append(Object lhs,
Object rhs)
Test if two
Objects are equal using their equals method. |
EqualsBuilder |
append(short[] lhs,
short[] rhs)
Deep comparison of array of
short. |
EqualsBuilder |
append(short lhs,
short rhs)
Test if two
shorts are equal. |
EqualsBuilder |
appendSuper(boolean superEquals)
Adds the result of
super.equals() to this builder. |
Boolean |
build()
Returns
true if the fields that have been checked are all equal. |
boolean |
isEquals()
Returns
true if the fields that have been checked are all equal. |
static boolean |
reflectionEquals(Object lhs,
Object rhs,
boolean testTransients)
This method uses reflection to determine if the two
Objects are equal. |
static boolean |
reflectionEquals(Object lhs,
Object rhs,
boolean testTransients,
Class<?> reflectUpToClass,
String... excludeFields)
This method uses reflection to determine if the two
Objects are equal. |
static boolean |
reflectionEquals(Object lhs,
Object rhs,
Collection<String> excludeFields)
反射检查两个对象是否equals,此方法检查对象及其父对象的属性(包括私有属性)是否equals
|
static boolean |
reflectionEquals(Object lhs,
Object rhs,
String... excludeFields)
反射检查两个对象是否equals,此方法检查对象及其父对象的属性(包括私有属性)是否equals
|
void |
reset()
Reset the EqualsBuilder so you can use the same object again
|
protected void |
setEquals(boolean isEquals)
Sets the
isEquals value. |
public static boolean reflectionEquals(Object lhs, Object rhs, Collection<String> excludeFields)
lhs - 此对象rhs - 另一个对象excludeFields - 排除的字段集合,如果有不参与计算equals的字段加入此集合即可truepublic static boolean reflectionEquals(Object lhs, Object rhs, String... excludeFields)
lhs - 此对象rhs - 另一个对象excludeFields - 排除的字段集合,如果有不参与计算equals的字段加入此集合即可truepublic static boolean reflectionEquals(Object lhs, Object rhs, boolean testTransients)
Objects are equal.
It uses AccessibleObject.setAccessible to gain access to private fields. This
means that it will throw a security exception if run under a security manager, if the
permissions are not set up correctly. It is also not as efficient as testing explicitly.
Non-primitive fields are compared using equals().
If the TestTransients parameter is set to true, transient members will be
tested, otherwise they are ignored, as they are likely derived fields, and not part of the
value of the Object.
Static fields will not be tested. Superclass fields will be included.
lhs - this objectrhs - the other objecttestTransients - whether to include transient fieldstrue if the two Objects have tested equals.public static boolean reflectionEquals(Object lhs, Object rhs, boolean testTransients, Class<?> reflectUpToClass, String... excludeFields)
Objects are equal.
It uses AccessibleObject.setAccessible to gain access to private fields. This
means that it will throw a security exception if run under a security manager, if the
permissions are not set up correctly. It is also not as efficient as testing explicitly.
Non-primitive fields are compared using equals().
If the testTransients parameter is set to true, transient members will be
tested, otherwise they are ignored, as they are likely derived fields, and not part of the
value of the Object.
Static fields will not be included. Superclass fields will be appended up to and including the specified superclass. A null superclass is treated as java.lang.Object.
lhs - this objectrhs - the other objecttestTransients - whether to include transient fieldsreflectUpToClass - the superclass to reflect up to (inclusive), may be nullexcludeFields - array of field names to exclude from testingtrue if the two Objects have tested equals.public EqualsBuilder appendSuper(boolean superEquals)
super.equals() to this builder.superEquals - the result of calling super.equals()public EqualsBuilder append(Object lhs, Object rhs)
Objects are equal using their equals method.lhs - the left hand objectrhs - the right hand objectpublic EqualsBuilder append(long lhs, long rhs)
long s are equal.lhs - the left hand longrhs - the right hand longpublic EqualsBuilder append(int lhs, int rhs)
ints are equal.lhs - the left hand intrhs - the right hand intpublic EqualsBuilder append(short lhs, short rhs)
shorts are equal.lhs - the left hand shortrhs - the right hand shortpublic EqualsBuilder append(char lhs, char rhs)
chars are equal.lhs - the left hand charrhs - the right hand charpublic EqualsBuilder append(byte lhs, byte rhs)
bytes are equal.lhs - the left hand byterhs - the right hand bytepublic EqualsBuilder append(double lhs, double rhs)
doubles are equal by testing that the pattern of bits returned by
doubleToLong are equal.
This handles NaNs, Infinities, and -0.0.
It is compatible with the hash code generated by HashCodeBuilder.
lhs - the left hand doublerhs - the right hand doublepublic EqualsBuilder append(float lhs, float rhs)
floats are equal byt testing that the pattern of bits returned by
doubleToLong are equal.
This handles NaNs, Infinities, and -0.0.
It is compatible with the hash code generated by HashCodeBuilder.
lhs - the left hand floatrhs - the right hand floatpublic EqualsBuilder append(boolean lhs, boolean rhs)
booleanss are equal.lhs - the left hand booleanrhs - the right hand booleanpublic EqualsBuilder append(Object[] lhs, Object[] rhs)
Object arrays.
This also will be called for the top level of multi-dimensional, ragged, and multi-typed arrays.
lhs - the left hand Object[]rhs - the right hand Object[]public EqualsBuilder append(long[] lhs, long[] rhs)
long. Length and all values are compared.
The method append(long, long) is used.
lhs - the left hand long[]rhs - the right hand long[]public EqualsBuilder append(int[] lhs, int[] rhs)
int. Length and all values are compared.
The method append(int, int) is used.
lhs - the left hand int[]rhs - the right hand int[]public EqualsBuilder append(short[] lhs, short[] rhs)
short. Length and all values are compared.
The method append(short, short) is used.
lhs - the left hand short[]rhs - the right hand short[]public EqualsBuilder append(char[] lhs, char[] rhs)
char. Length and all values are compared.
The method append(char, char) is used.
lhs - the left hand char[]rhs - the right hand char[]public EqualsBuilder append(byte[] lhs, byte[] rhs)
byte. Length and all values are compared.
The method append(byte, byte) is used.
lhs - the left hand byte[]rhs - the right hand byte[]public EqualsBuilder append(double[] lhs, double[] rhs)
double. Length and all values are compared.
The method append(double, double) is used.
lhs - the left hand double[]rhs - the right hand double[]public EqualsBuilder append(float[] lhs, float[] rhs)
float. Length and all values are compared.
The method append(float, float) is used.
lhs - the left hand float[]rhs - the right hand float[]public EqualsBuilder append(boolean[] lhs, boolean[] rhs)
boolean. Length and all values are compared.
The method append(boolean, boolean) is used.
lhs - the left hand boolean[]rhs - the right hand boolean[]public boolean isEquals()
true if the fields that have been checked are all equal.protected void setEquals(boolean isEquals)
isEquals value.isEquals - The value to set.public Boolean build()
true if the fields that have been checked are all equal.public void reset()
Copyright © 2023. All rights reserved.