Definition: An association is the abstraction of a set of domain relationships that hold systematically between different kinds of conceptual entities, abstracted as classes, in the domain.
The association is stated in terms of the classes abstracted from the domain. Associations are shown on the class diagram as lines drawn between the two participating classes. The lines on the diagram are labeled with the association names, association ends, and multiplicities. 6.1.1 Association NamesEach association has a name. The name is an arbitrary identifier that can be meaningful to the association or can simply be a label, such as R12 for the "twelfth relationship." Executable UML uses relationship names to identify the association unambiguously. (We call these names relationship numbers and we will use them to identify associations and as a discriminator in generalization hierarchies.) 6.1.2 Association MeaningsEach association's meaning is expressed in terms of an association end. Not surprisingly, given its name, an association end is a string that appears at the end of an association. The string may be a role or a verb phrase. Roles.Each of the two classes in an association has a role. Write the role names next to the relevant classes as shown in Figure 6.1. Figure 6.1. Class Diagram with Association Names and RolesVerb phrases.In some cases it may be difficult to identify a role name that is distinct from the name of the related class. A more meaningful way to state the association is to write its meaning in terms of verb phrases. By convention, the phrase is placed next to the direct object of the sentence, as you can see in Figure 6.2. Figure 6.2. Associations Using Verb PhrasesUsing verb phrases has the distinct advantage of providing more descriptive text on the class diagram, and it avoids the search for role names different from the class names, or just leaving the role name blank.
6.1.3 MultiplicityAssociations involving only two objects can be characterized by the number of instances that participate in each instance of the domain relationship. This is represented in UML as a multiplicity, a range defining the number of participating instances. The values for a range can be between zero and an "indefinite number." Executable UML defines exactly four multiplicities: 1..1, 1..*, 0..1, and 0..*. The first two the ones that start with one are unconditional (or mandatory, if you prefer) because at least one instance must participate, and the last two the ones that start with zero are conditional. In the examples in Figure 6.3, the association between Book and Author is unconditional; one is not an Author unless he has written a Book and every Book has at least one credited Author. (The model ignores the idea of anonymously authored books. If it didn't, we would use a conditional association.) Figure 6.3. Associations with MultiplicitiesThe Book Customer association is conditional: A Customer is someone who has purchased books; but, there can be books that no one purchases.
|