88

Consider the below two diagrams. The top one contains a plain arrow at the right end, and the bottom one contains an arrow with a diamond at the left end and a plain arrow at the right end. The great book GoF has usages of both of these two kinds of diagrams.

I want to understand what does the diamond signify in the second case, and which one of these two gives a stronger association between Customer and Order.

Is the Customer class responsible for the lifecycle of Order class in either of the two cases?

enter image description here enter image description here

TylerH
  • 20,799
  • 66
  • 75
  • 101
Geek
  • 26,489
  • 43
  • 149
  • 227

3 Answers3

138

If there is no diamond, then we have a simple association.

If the diamond is left empty, it signifies it is an aggregation. This relation is stronger than a simple association. In this case a Customer aggregates Orders.

If the diamond is black, this means it is a composition, which is even stronger than an aggregation because the composite class cannot be composite by other classes. Its "life" depends on the container.

I think it's explained a little bit more clearly, at:

vaeVictis
  • 484
  • 1
  • 3
  • 13
C.Champagne
  • 5,381
  • 2
  • 23
  • 35
24

The customer and order is a "has-a" composition relationship because if the customer ceases to exist so does his/her order. Therefore, there is a life cycle dependency between the container (customer) and the instances within that container (order). When the container ceases to exist so does all its instances.

On the other hand, if we say a customer has a book. In this case, we have a "has-a" aggregation relationship. Because if the customer ceases to exist, the book is still available.

Rubens Gomes
  • 241
  • 2
  • 2
10

It signifies aggregation. From wikipedia:

In UML, it is graphically represented as a hollow diamond shape on the containing class end of the tree with a single line that connects the contained class to the containing class.The aggregate is semantically an extended object that is treated as a unit in many operations,although physically it is made of several lesser objects.

http://en.wikipedia.org/wiki/Class_diagram

Mike Darmetko
  • 151
  • 1
  • 6