Java Doc for EqualsBuilder.java in  » Library » Apache-common-lang » org » apache » commons » lang » builder » Java Source Code / Java DocumentationJava Source Code and Java Documentation

Java Source Code / Java Documentation
1. 6.0 JDK Core
2. 6.0 JDK Modules
3. 6.0 JDK Modules com.sun
4. 6.0 JDK Modules com.sun.java
5. 6.0 JDK Modules sun
6. 6.0 JDK Platform
7. Ajax
8. Apache Harmony Java SE
9. Aspect oriented
10. Authentication Authorization
11. Blogger System
12. Build
13. Byte Code
14. Cache
15. Chart
16. Chat
17. Code Analyzer
18. Collaboration
19. Content Management System
20. Database Client
21. Database DBMS
22. Database JDBC Connection Pool
23. Database ORM
24. Development
25. EJB Server geronimo
26. EJB Server GlassFish
27. EJB Server JBoss 4.2.1
28. EJB Server resin 3.1.5
29. ERP CRM Financial
30. ESB
31. Forum
32. GIS
33. Graphic Library
34. Groupware
35. HTML Parser
36. IDE
37. IDE Eclipse
38. IDE Netbeans
39. Installer
40. Internationalization Localization
41. Inversion of Control
42. Issue Tracking
43. J2EE
44. JBoss
45. JMS
46. JMX
47. Library
48. Mail Clients
49. Net
50. Parser
51. PDF
52. Portal
53. Profiler
54. Project Management
55. Report
56. RSS RDF
57. Rule Engine
58. Science
59. Scripting
60. Search Engine
61. Security
62. Sevlet Container
63. Source Control
64. Swing Library
65. Template Engine
66. Test Coverage
67. Testing
68. UML
69. Web Crawler
70. Web Framework
71. Web Mail
72. Web Server
73. Web Services
74. Web Services apache cxf 2.0.1
75. Web Services AXIS2
76. Wiki Engine
77. Workflow Engines
78. XML
79. XML UI
Java
Java Tutorial
Java Open Source
Jar File Download
Java Articles
Java Products
Java by API
Photoshop Tutorials
Maya Tutorials
Flash Tutorials
3ds-Max Tutorials
Illustrator Tutorials
GIMP Tutorials
C# / C Sharp
C# / CSharp Tutorial
C# / CSharp Open Source
ASP.Net
ASP.NET Tutorial
JavaScript DHTML
JavaScript Tutorial
JavaScript Reference
HTML / CSS
HTML CSS Reference
C / ANSI-C
C Tutorial
C++
C++ Tutorial
Ruby
PHP
Python
Python Tutorial
Python Open Source
SQL Server / T-SQL
SQL Server / T-SQL Tutorial
Oracle PL / SQL
Oracle PL/SQL Tutorial
PostgreSQL
SQL / MySQL
MySQL Tutorial
VB.Net
VB.Net Tutorial
Flash / Flex / ActionScript
VBA / Excel / Access / Word
XML
XML Tutorial
Microsoft Office PowerPoint 2007 Tutorial
Microsoft Office Excel 2007 Tutorial
Microsoft Office Word 2007 Tutorial
Java Source Code / Java Documentation » Library » Apache common lang » org.apache.commons.lang.builder 
Source Cross Reference  Class Diagram Java Document (Java Doc) 


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 $



Constructor Summary
public  EqualsBuilder()
    

Method Summary
public  EqualsBuilderappend(Object lhs, Object rhs)
    
public  EqualsBuilderappend(long lhs, long rhs)
    

Test if two long s are equal.

public  EqualsBuilderappend(int lhs, int rhs)
    
public  EqualsBuilderappend(short lhs, short rhs)
    
public  EqualsBuilderappend(char lhs, char rhs)
    
public  EqualsBuilderappend(byte lhs, byte rhs)
    
public  EqualsBuilderappend(double lhs, double rhs)
    
public  EqualsBuilderappend(float lhs, float rhs)
    
public  EqualsBuilderappend(boolean lhs, boolean rhs)
    
public  EqualsBuilderappend(Object[] lhs, Object[] rhs)
    
public  EqualsBuilderappend(long[] lhs, long[] rhs)
    

Deep comparison of array of long.

public  EqualsBuilderappend(int[] lhs, int[] rhs)
    

Deep comparison of array of int.

public  EqualsBuilderappend(short[] lhs, short[] rhs)
    

Deep comparison of array of short.

public  EqualsBuilderappend(char[] lhs, char[] rhs)
    

Deep comparison of array of char.

public  EqualsBuilderappend(byte[] lhs, byte[] rhs)
    

Deep comparison of array of byte.

public  EqualsBuilderappend(double[] lhs, double[] rhs)
    

Deep comparison of array of double.

public  EqualsBuilderappend(float[] lhs, float[] rhs)
    

Deep comparison of array of float.

public  EqualsBuilderappend(boolean[] lhs, boolean[] rhs)
    

Deep comparison of array of boolean.

public  EqualsBuilderappendSuper(boolean superEquals)
    
public  booleanisEquals()
    
public static  booleanreflectionEquals(Object lhs, Object rhs)
    

This method uses reflection to determine if the two Objects are equal.

It uses AccessibleObject.setAccessible to gain access to private fields.

public static  booleanreflectionEquals(Object lhs, Object rhs, Collection excludeFields)
    

This method uses reflection to determine if the two Objects are equal.

It uses AccessibleObject.setAccessible to gain access to private fields.

public static  booleanreflectionEquals(Object lhs, Object rhs, String[] excludeFields)
    

This method uses reflection to determine if the two Objects are equal.

It uses AccessibleObject.setAccessible to gain access to private fields.

public static  booleanreflectionEquals(Object lhs, Object rhs, boolean testTransients)
    

This method uses reflection to determine if the two Objects are equal.

It uses AccessibleObject.setAccessible to gain access to private fields.

public static  booleanreflectionEquals(Object lhs, Object rhs, boolean testTransients, Class reflectUpToClass)
    

This method uses reflection to determine if the two Objects are equal.

It uses AccessibleObject.setAccessible to gain access to private fields.

public static  booleanreflectionEquals(Object lhs, Object rhs, boolean testTransients, Class reflectUpToClass, String[] excludeFields)
    

This method uses reflection to determine if the two Objects are equal.

It uses AccessibleObject.setAccessible to gain access to private fields.

protected  voidsetEquals(boolean isEquals)
     Sets the isEquals value.


Constructor Detail
EqualsBuilder
public EqualsBuilder()(Code)

Constructor for EqualsBuilder.

Starts off assuming that equals is true.


See Also:   Object.equals(Object)




Method Detail
append
public EqualsBuilder append(Object lhs, Object rhs)(Code)

Test if two Objects 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 ints 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 shorts 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 chars 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 bytes 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 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.


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 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.


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 booleanss 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 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.

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 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.

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 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.

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 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.

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 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.

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 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.

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



Methods inherited from java.lang.Object
native protected Object clone() throws CloneNotSupportedException(Code)(Java Doc)
public boolean equals(Object obj)(Code)(Java Doc)
protected void finalize() throws Throwable(Code)(Java Doc)
final native public Class getClass()(Code)(Java Doc)
native public int hashCode()(Code)(Java Doc)
final native public void notify()(Code)(Java Doc)
final native public void notifyAll()(Code)(Java Doc)
public String toString()(Code)(Java Doc)
final native public void wait(long timeout) throws InterruptedException(Code)(Java Doc)
final public void wait(long timeout, int nanos) throws InterruptedException(Code)(Java Doc)
final public void wait() throws InterruptedException(Code)(Java Doc)

www.java2java.com | Contact Us
Copyright 2009 - 12 Demo Source and Support. All rights reserved.
All other trademarks are property of their respective owners.