Buscar..


Implementar el método equals ()

Para implementar fácilmente el método equals de un objeto, puede usar la clase EqualsBuilder .

Seleccionando los campos:

@Override
public boolean equals(Object obj) {

    if(!(obj instanceof MyClass)) {
        return false;
    }
    MyClass theOther = (MyClass) obj;
    
    EqualsBuilder builder = new EqualsBuilder();
    builder.append(field1, theOther.field1);
    builder.append(field2, theOther.field2);
    builder.append(field3, theOther.field3);
    
    return builder.isEquals();
}

Usando la reflexión:

@Override
public boolean equals(Object obj) {
    return EqualsBuilder.reflectionEquals(this, obj, false);
}

el parámetro booleano es para indicar si los iguales deben verificar los campos transitorios.

Usando la reflexión evitando algunos campos:

@Override
public boolean equals(Object obj) {
    return EqualsBuilder.reflectionEquals(this, obj, "field1", "field2");
}

Implementar el método hashCode ()

Para implementar hashCode método hashCode de un objeto, puede usar la clase HashCodeBuilder .

Seleccionando los campos:

@Override
public int hashCode() {
    
    HashCodeBuilder builder = new HashCodeBuilder();
    builder.append(field1);
    builder.append(field2);
    builder.append(field3);
    
    return builder.hashCode();
}

Usando la reflexión:

@Override
public int hashCode() {
    return HashCodeBuilder.reflectionHashCode(this, false);
}

el parámetro booleano indica si debe usar campos transitorios.

Usando la reflexión evitando algunos campos:

@Override
public int hashCode() {
    return HashCodeBuilder.reflectionHashCode(this, "field1", "field2");
}

Implementar el método toString ()

Para implementar fácilmente el método toString de un objeto, puede usar la clase ToStringBuilder .

Seleccionando los campos:

@Override
public String toString() {

    ToStringBuilder builder = new ToStringBuilder(this);
    builder.append(field1);
    builder.append(field2);
    builder.append(field3);
    
    return builder.toString();
}

Resultado de ejemplo:

ar.com.jonat.lang.MyClass@dd7123[<null>,0,false]

Dando nombres explícitos a los campos:

@Override
public String toString() {

    ToStringBuilder builder = new ToStringBuilder(this);
    builder.append("field1",field1);
    builder.append("field2",field2);
    builder.append("field3",field3);
    
    return builder.toString();
}

Resultado de ejemplo:

ar.com.jonat.lang.MyClass@dd7404[field1=<null>,field2=0,field3=false]

Podrías cambiar el estilo vía parámetro:

@Override
public String toString() {

    ToStringBuilder builder = new ToStringBuilder(this,
            ToStringStyle.MULTI_LINE_STYLE);
    builder.append("field1", field1);
    builder.append("field2", field2);
    builder.append("field3", field3);

    return builder.toString();
}

Resultado de ejemplo:

ar.com.bna.lang.MyClass@ebbf5c[
  field1=<null>
  field2=0
  field3=false
]

Hay algunos estilos, por ejemplo JSON, sin nombre de clase, cortos, etc.

Vía la reflexión:

@Override
public String toString() {
    return ToStringBuilder.reflectionToString(this);
}

También puedes indicar el estilo:

@Override
public String toString() {
    return ToStringBuilder.reflectionToString(this, ToStringStyle.JSON_STYLE);
}


Modified text is an extract of the original Stack Overflow Documentation
Licenciado bajo CC BY-SA 3.0
No afiliado a Stack Overflow