本文次要钻研一下dddsample-core的model

Entity

public interface Entity<T> {  /**   * Entities compare by identity, not by attributes.   *   * @param other The other entity.   * @return true if the identities are the same, regardless of other attributes.   */  boolean sameIdentityAs(T other);}
Entity接口定义了sameIdentityAs办法

ValueObject

public interface ValueObject<T> extends Serializable {  /**   * Value objects compare by the values of their attributes, they don't have an identity.   *   * @param other The other value object.   * @return <code>true</code> if the given value object's and this value object's attributes are the same.   */  boolean sameValueAs(T other);}
ValueObject接口定义了sameValueAs办法

TrackingId

public final class TrackingId implements ValueObject<TrackingId> {  private String id;  /**   * Constructor.   *   * @param id Id string.   */  public TrackingId(final String id) {    Validate.notNull(id);    this.id = id;  }  /**   * @return String representation of this tracking id.   */  public String idString() {    return id;  }  @Override  public boolean equals(Object o) {    if (this == o) return true;    if (o == null || getClass() != o.getClass()) return false;    TrackingId other = (TrackingId) o;    return sameValueAs(other);  }  @Override  public int hashCode() {    return id.hashCode();  }  @Override  public boolean sameValueAs(TrackingId other) {    return other != null && this.id.equals(other.id);  }  @Override  public String toString() {    return id;  }  TrackingId() {    // Needed by Hibernate  }}
TrackingId实现了ValueObject接口,sameValueAs办法通过equals办法判断

Type

  public enum Type implements ValueObject<Type> {    LOAD(true),    UNLOAD(true),    RECEIVE(false),    CLAIM(false),    CUSTOMS(false);    private final boolean voyageRequired;    /**     * Private enum constructor.     *     * @param voyageRequired whether or not a voyage is associated with this event type     */    private Type(final boolean voyageRequired) {      this.voyageRequired = voyageRequired;    }    /**     * @return True if a voyage association is required for this event type.     */    public boolean requiresVoyage() {      return voyageRequired;    }    /**     * @return True if a voyage association is prohibited for this event type.     */    public boolean prohibitsVoyage() {      return !requiresVoyage();    }    @Override    public boolean sameValueAs(Type other) {      return other != null && this.equals(other);    }  }
Type枚举实现了ValueObject接口,其sameValueAs办法通过equals判断

DomainEvent

public interface DomainEvent<T> {  /**   * @param other The other domain event.   * @return <code>true</code> if the given domain event and this event are regarded as being the same event.   */  boolean sameEventAs(T other);}
DomainEvent接口定义了sameEventAs办法

小结

dddsample-core定义了Entity、ValueObject、DomainEvent接口,它们别离定义了sameIdentityAs、sameValueAs、sameEventAs办法。

doc

  • dddsample-core