Tuesday, November 24, 2009

Aggregation Vs Composition

Aggregation:

  • Weak “has-a” relationship between aggregate (whole) and component (part), as component object may survive without aggregate object.

  • Component object may be accessed through other objects without going through the aggregate object.

  • Aggregate object does not participate in the life cycle of component object, meaning the component object may outlive the aggregate object.

  • State of component object still forms part of the aggregate object.

Example: History-Class object contains zero or more of Student objects. The state of each Student object has an influence on the state of the History-Class object. If the History-Class object is destroyed, the Student objects may continue to exist.

The UML diagram above illustrates the aggregation association line with an open diamond on the aggregate side.

Composition:

  • Strong “has-a” relationship between the composite (whole) and component (part), as the composite object takes ownership of the component, meaning composite is responsible for creation and destruction of the component parts.

  • Component may only be part of one composite.

  • If the composite object is destroyed, all the component parts must be destroyed, or the reference and responsibility of the component part must be handed over to another object.

  • Composite enforces encapsulation as the component parts usually are members of the composite objects.

Example: House object contains zero or more Room objects. The state of each Room object has an influence on the House object. If the House object is destroyed, the Room objects will also be destroyed.

The UML diagram above illustrates the composition association line with a solid diamond on the composite side.

No comments: