| java.lang.Object org.apache.commons.lang.builder.EqualsBuilder
EqualsBuilder | public class EqualsBuilder (Code) | | Assists in implementing
Object.equals(Object) methods.
This class provides methods to build a good equals method for any
class. It follows rules laid out in
Effective Java
, by Joshua Bloch. In particular the rule for comparing doubles ,
floats , and arrays can be tricky. Also, making sure that
equals() and hashCode() are consistent can be
difficult.
Two Objects that compare as equals must generate the same hash code,
but two Objects with the same hash code do not have to be equal.
All relevant fields should be included in the calculation of equals.
Derived fields may be ignored. In particular, any field used in
generating a hash code must be used in the equals method, and vice
versa.
Typical use for the code is as follows:
public boolean equals(Object obj) {
if (obj instanceof MyClass == false) {
return false;
}
if (this == obj) {
return true;
}
MyClass rhs = (MyClass) obj;
return new EqualsBuilder()
.appendSuper(super.equals(obj))
.append(field1, rhs.field1)
.append(field2, rhs.field2)
.append(field3, rhs.field3)
.isEquals();
}
Alternatively, there is a method that uses reflection to determine
the fields to test. Because these fields are usually private, the method,
reflectionEquals , uses AccessibleObject.setAccessible to
change the visibility of the fields. This will fail under a security
manager, unless the appropriate permissions are set up correctly. It is
also slower than testing explicitly.
A typical invocation for this method would look like:
public boolean equals(Object obj) {
return EqualsBuilder.reflectionEquals(this, obj);
}
author: Steve Downey author: Stephen Colebourne author: Gary Gregory author: Pete Gieser author: Arun Mammen Thomas since: 1.0 version: $Id: EqualsBuilder.java 437554 2006-08-28 06:21:41Z bayard $ |
Method Summary | |
public EqualsBuilder | append(Object lhs, Object rhs) | public EqualsBuilder | append(long lhs, long rhs)
Test if two long s are equal. | public EqualsBuilder | append(int lhs, int rhs) | public EqualsBuilder | append(short lhs, short rhs) | public EqualsBuilder | append(char lhs, char rhs) | public EqualsBuilder | append(byte lhs, byte rhs) | public EqualsBuilder | append(double lhs, double rhs) | public EqualsBuilder | append(float lhs, float rhs) | public EqualsBuilder | append(boolean lhs, boolean rhs) | public EqualsBuilder | append(Object[] lhs, Object[] rhs) | public EqualsBuilder | append(long[] lhs, long[] rhs) Deep comparison of array of long . | public EqualsBuilder | append(int[] lhs, int[] rhs) Deep comparison of array of int . | public EqualsBuilder | append(short[] lhs, short[] rhs) Deep comparison of array of short . | public EqualsBuilder | append(char[] lhs, char[] rhs) Deep comparison of array of char . | public EqualsBuilder | append(byte[] lhs, byte[] rhs) Deep comparison of array of byte . | public EqualsBuilder | append(double[] lhs, double[] rhs) Deep comparison of array of double . | public EqualsBuilder | append(float[] lhs, float[] rhs) Deep comparison of array of float . | public EqualsBuilder | append(boolean[] lhs, boolean[] rhs) Deep comparison of array of boolean . | public EqualsBuilder | appendSuper(boolean superEquals) | public boolean | isEquals() | public static boolean | reflectionEquals(Object lhs, Object rhs) This method uses reflection to determine if the two Object s
are equal.
It uses AccessibleObject.setAccessible to gain access to private
fields. | public static boolean | reflectionEquals(Object lhs, Object rhs, Collection excludeFields) This method uses reflection to determine if the two Object s
are equal.
It uses AccessibleObject.setAccessible to gain access to private
fields. | public static boolean | reflectionEquals(Object lhs, Object rhs, String[] excludeFields) This method uses reflection to determine if the two Object s
are equal.
It uses AccessibleObject.setAccessible to gain access to private
fields. | public static boolean | reflectionEquals(Object lhs, Object rhs, boolean testTransients) This method uses reflection to determine if the two Object s
are equal.
It uses AccessibleObject.setAccessible to gain access to private
fields. | public static boolean | reflectionEquals(Object lhs, Object rhs, boolean testTransients, Class reflectUpToClass) This method uses reflection to determine if the two Object s
are equal.
It uses AccessibleObject.setAccessible to gain access to private
fields. | public static boolean | reflectionEquals(Object lhs, Object rhs, boolean testTransients, Class reflectUpToClass, String[] excludeFields) This method uses reflection to determine if the two Object s
are equal.
It uses AccessibleObject.setAccessible to gain access to private
fields. | protected void | setEquals(boolean isEquals) Sets the isEquals value. |
EqualsBuilder | public EqualsBuilder()(Code) | | Constructor for EqualsBuilder.
Starts off assuming that equals is true .
See Also: Object.equals(Object) |
append | public EqualsBuilder append(Object lhs, Object rhs)(Code) | | Test if two Object s are equal using their
equals method.
Parameters: lhs - the left hand object Parameters: rhs - the right hand object EqualsBuilder - used to chain calls. |
append | public EqualsBuilder append(long lhs, long rhs)(Code) | |
Test if two long s are equal.
Parameters: lhs - the left hand long Parameters: rhs - the right hand long EqualsBuilder - used to chain calls. |
append | public EqualsBuilder append(int lhs, int rhs)(Code) | | Test if two int s are equal.
Parameters: lhs - the left hand int Parameters: rhs - the right hand int EqualsBuilder - used to chain calls. |
append | public EqualsBuilder append(short lhs, short rhs)(Code) | | Test if two short s are equal.
Parameters: lhs - the left hand short Parameters: rhs - the right hand short EqualsBuilder - used to chain calls. |
append | public EqualsBuilder append(char lhs, char rhs)(Code) | | Test if two char s are equal.
Parameters: lhs - the left hand char Parameters: rhs - the right hand char EqualsBuilder - used to chain calls. |
append | public EqualsBuilder append(byte lhs, byte rhs)(Code) | | Test if two byte s are equal.
Parameters: lhs - the left hand byte Parameters: rhs - the right hand byte EqualsBuilder - used to chain calls. |
append | public EqualsBuilder append(double lhs, double rhs)(Code) | | Test if two double s 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 .
Parameters: lhs - the left hand double Parameters: rhs - the right hand double EqualsBuilder - used to chain calls. |
append | public EqualsBuilder append(float lhs, float rhs)(Code) | | Test if two float s 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 .
Parameters: lhs - the left hand float Parameters: rhs - the right hand float EqualsBuilder - used to chain calls. |
append | public EqualsBuilder append(boolean lhs, boolean rhs)(Code) | | Test if two booleans s are equal.
Parameters: lhs - the left hand boolean Parameters: rhs - the right hand boolean EqualsBuilder - used to chain calls. |
append | public EqualsBuilder append(Object[] lhs, Object[] rhs)(Code) | | Performs a deep comparison of two Object arrays.
This also will be called for the top level of
multi-dimensional, ragged, and multi-typed arrays.
Parameters: lhs - the left hand Object[] Parameters: rhs - the right hand Object[] EqualsBuilder - used to chain calls. |
append | public EqualsBuilder append(long[] lhs, long[] rhs)(Code) | | Deep comparison of array of long . Length and all
values are compared.
The method
EqualsBuilder.append(long,long) is used.
Parameters: lhs - the left hand long[] Parameters: rhs - the right hand long[] EqualsBuilder - used to chain calls. |
append | public EqualsBuilder append(int[] lhs, int[] rhs)(Code) | | Deep comparison of array of int . Length and all
values are compared.
The method
EqualsBuilder.append(int,int) is used.
Parameters: lhs - the left hand int[] Parameters: rhs - the right hand int[] EqualsBuilder - used to chain calls. |
append | public EqualsBuilder append(short[] lhs, short[] rhs)(Code) | | Deep comparison of array of short . Length and all
values are compared.
The method
EqualsBuilder.append(short,short) is used.
Parameters: lhs - the left hand short[] Parameters: rhs - the right hand short[] EqualsBuilder - used to chain calls. |
append | public EqualsBuilder append(char[] lhs, char[] rhs)(Code) | | Deep comparison of array of char . Length and all
values are compared.
The method
EqualsBuilder.append(char,char) is used.
Parameters: lhs - the left hand char[] Parameters: rhs - the right hand char[] EqualsBuilder - used to chain calls. |
append | public EqualsBuilder append(byte[] lhs, byte[] rhs)(Code) | | Deep comparison of array of byte . Length and all
values are compared.
The method
EqualsBuilder.append(byte,byte) is used.
Parameters: lhs - the left hand byte[] Parameters: rhs - the right hand byte[] EqualsBuilder - used to chain calls. |
append | public EqualsBuilder append(double[] lhs, double[] rhs)(Code) | | Deep comparison of array of double . Length and all
values are compared.
The method
EqualsBuilder.append(double,double) is used.
Parameters: lhs - the left hand double[] Parameters: rhs - the right hand double[] EqualsBuilder - used to chain calls. |
append | public EqualsBuilder append(float[] lhs, float[] rhs)(Code) | | Deep comparison of array of float . Length and all
values are compared.
The method
EqualsBuilder.append(float,float) is used.
Parameters: lhs - the left hand float[] Parameters: rhs - the right hand float[] EqualsBuilder - used to chain calls. |
append | public EqualsBuilder append(boolean[] lhs, boolean[] rhs)(Code) | | Deep comparison of array of boolean . Length and all
values are compared.
The method
EqualsBuilder.append(boolean,boolean) is used.
Parameters: lhs - the left hand boolean[] Parameters: rhs - the right hand boolean[] EqualsBuilder - used to chain calls. |
appendSuper | public EqualsBuilder appendSuper(boolean superEquals)(Code) | | Adds the result of super.equals() to this builder.
Parameters: superEquals - the result of calling super.equals() EqualsBuilder - used to chain calls. since: 2.0 |
isEquals | public boolean isEquals()(Code) | | Returns true if the fields that have been checked
are all equal.
boolean |
reflectionEquals | public static boolean reflectionEquals(Object lhs, Object rhs)(Code) | | This method uses reflection to determine if the two Object s
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.
Transient members will be not be tested, 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.
Parameters: lhs - this object Parameters: rhs - the other object true if the two Objects have tested equals. |
reflectionEquals | public static boolean reflectionEquals(Object lhs, Object rhs, Collection excludeFields)(Code) | | This method uses reflection to determine if the two Object s
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.
Transient members will be not be tested, 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.
Parameters: lhs - this object Parameters: rhs - the other object Parameters: excludeFields - Collection of String field names to exclude from testing true if the two Objects have tested equals. |
reflectionEquals | public static boolean reflectionEquals(Object lhs, Object rhs, String[] excludeFields)(Code) | | This method uses reflection to determine if the two Object s
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.
Transient members will be not be tested, 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.
Parameters: lhs - this object Parameters: rhs - the other object Parameters: excludeFields - array of field names to exclude from testing true if the two Objects have tested equals. |
reflectionEquals | public static boolean reflectionEquals(Object lhs, Object rhs, boolean testTransients)(Code) | | This method uses reflection to determine if the two Object s
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.
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.
Parameters: lhs - this object Parameters: rhs - the other object Parameters: testTransients - whether to include transient fields true if the two Objects have tested equals. |
reflectionEquals | public static boolean reflectionEquals(Object lhs, Object rhs, boolean testTransients, Class reflectUpToClass)(Code) | | This method uses reflection to determine if the two Object s
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.
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.
Parameters: lhs - this object Parameters: rhs - the other object Parameters: testTransients - whether to include transient fields Parameters: reflectUpToClass - the superclass to reflect up to (inclusive),may be null true if the two Objects have tested equals. since: 2.0 |
reflectionEquals | public static boolean reflectionEquals(Object lhs, Object rhs, boolean testTransients, Class reflectUpToClass, String[] excludeFields)(Code) | | This method uses reflection to determine if the two Object s
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.
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.
Parameters: lhs - this object Parameters: rhs - the other object Parameters: testTransients - whether to include transient fields Parameters: reflectUpToClass - the superclass to reflect up to (inclusive),may be null Parameters: excludeFields - array of field names to exclude from testing true if the two Objects have tested equals. since: 2.0 |
setEquals | protected void setEquals(boolean isEquals)(Code) | | Sets the isEquals value.
Parameters: isEquals - The value to set. since: 2.1 |
|
|