In this unit we will examine the UML diagram types. UML (the Unified Modelling Language) is a well-known diagramming framework for software development. In the first part of this unit we will cover the history and diagram types, and in the second part we will examine how to use UML to analyse and design software.
- Define UML and its history.
- Describe the fourteen UML diagram types.
From Wikipedia(emphasis mine):
The Unified Modeling Language (UML) is a general-purpose, developmental, modeling language in the field of software engineering, that is intended to provide a standard way to visualize the design of a system.
So UML is meant to:
- be general-purpose (i.e., support general software modelling).
- be developmental (i.e., enable model and system development).
- be a modelling language, which is more than just a set of diagrams.
- provide a method to visualise system design.
In this module we are mainly using UML in the last point: visualising system design. However, UML itself can be used to develop a system where the models allow the generation of actual code.
The clue to UML's history is in the first part of its name: unified. UML is actually a coming together of three different approaches to modelling object-oriented software:
- Booch method.
- Object-Modelling Technique (OMT).
- Object-Oriented Software Engineering (OOSE).
The Booch method had features such as class diagrams, object diagrams, state diagrams, sequence diagrams, component diagrams, and deployment diagrams. In effect, the Booch method had most of the current popular UML features. However, the Booch method was somewhat lighter on detail in these diagrams than current UML.
OMT also features class diagrams and state diagrams. The class diagrams in OMT are more reminiscent of current UML class diagrams than the Booch method.
The main contribution of OOSE is the use-case diagram. As users are seen as the main driving force behind what we build as software engineers, use case diagrams are seen as one of the key diagrams of UML.
By 1995, all three main diagram proponents (Grady Booch, Ivar Jacobson, and James Rumbaugh) were working at Rational Software. This led to the creation of a UML Partners consortium in 1996, with the first UML standard proposed in 1997.
In 2005 two major events happened:
- The UML 2.0 standard was adopted.
- The International Organization for Standardization (ISO) approved an ISO standard for UML.
So UML is a standardised method and set of diagrams, but it has come from a three different sources. This is why UML can sometimes seem a little disjointed in what it is trying to present. One of the key things to remember is UML can be used to visualise information about the software development process. Visualisation is one of the key aspects of DevOps - we want to be able to see what is happening. UML can easily be generated from existing code to perform this task.
UML defines several types of diagram which are useful at different stages of the software development lifecycle. The diagrams can be split into two broad types:
- Behavioural diagrams define what happens the functionality of the system. This includes a sub-type of behavioural diagrams:
- Interaction diagrams model the flow-of-control and data in the system.
- Structural diagrams model the architecture and relationship between components of the system.
We will look at each one of these diagrams in turn, starting with behavioural diagrams. The reason we start with behavioural diagrams is they feature two of the most common diagrams used to initiate design modelling: the use case diagram and the activity diagram.
Behavioural diagrams allow us to model what our system will do: the functionality. There are seven behavioural diagram types:
- Use Case Diagrams.
- Activity Diagrams.
- State Machine Diagrams.
- Sequence Diagrams.
- Interaction Overview Diagrams.
- Timing Diagrams.
- Communication Diagrams.
Of these seven, three have popular usage: use case, activity, and sequence. State diagrams are also popular, although state modelling in computing is normally different than UML's approach.
The point of a UML diagram is to capture the user's interaction with a system. It shows the use cases defined for the system, which users (actors) interact with them, and how these use cases interact with the system.
By Kishorekumar 62, CC BY-SA 3.0, Link
A use case diagram has three core elements:
- Actors who use the system, or are used by the system. These are represented by stick figures for people and boxes for systems.
- Use Cases which define how the system is used. These are represented by ovals.
- Interactions which show who invokes a use case, or how a use case interacts with other use cases. These are represented by lines and arrows.
Two special types of interactions are:
- Extends when a use case extends upon a more generalised use case.
- Includes when a use case includes another for functionality.
Activity diagrams allow us to model processes and workflows as a series of actions. They are essentially a flowchart. An example of a UML activity diagram is:
By spanish Wikipedia user Gwaur, CC BY-SA 3.0, Link
- Initial node where the workflow starts. This is represented by a black circle.
- Actions where something occurs in the workflow. Actions are represented by ellipses.
- Decisions where the workflow can go down different paths. These are represented by diamonds.
- Concurrent activity (split and join) indicates where actions can happen at the same time or in any order. A bar indicates the start of the activity and another bar the end. All activities between the bars must be completed before workflow can progress.
- Final node where the workflow ends. This is represented by an encircled black circle.
Arrows are used to indicate how the activity diagram should be followed.
State modelling in computing is a large topic in itself. For UML, we are only concerned with object and system state, which is a little easier to manage.
An object can only be in one of a selection of states. In a State Machine Diagram we are trying to illustrate how these states are transitioned into. An example is:
By Mirosamek (talk) - I (Mirosamek (talk)) created this work entirely by myself., CC BY-SA 3.0, Link
Interaction diagrams try and model how components interact during system execution. This is a sub-type of behaviour featuring the following four diagrams:
- Sequence Diagrams.
- Interaction Overview Diagrams.
- Timing Diagrams.
- Communication Diagrams.
Of these four, only sequence diagrams see common usage.
Sequence diagrams visualise how objects interact over time during method calls. They allow us to see the flow of interactions between objects, which enables us to determine side-effects when we make a method call. An example diagram is:
By Coupling_loss_graph.svg - File:CheckEmail.png, CC BY-SA 3.0, Link
Arrows indicate the subsequent method calls between the objects. Responses are sent back as dotted line arrows.
In simple terms, an interaction overview diagram is like an activity diagram but where an activity node contains another interaction diagram. For example:
By Stkl - Own work, translation from German version Uml-Iod-Diagramm1.svg, CC BY-SA 4.0, Link
A timing diagram is similar to a sequence diagram but with time now being the main access. An example is:
Taken from Timing Diagrams https://www.uml-diagrams.org/timing-diagrams.html.
Here we see how different objects change state and interact over time. We also add some time constraints. If timing performance is important to your project then the timing diagram may be useful.
The communication diagram illustrates similar information to the class, sequence, and use case diagrams arranged in a different form. For example:
By Oemmler - Omnigraffle Modeling tool
Previously published: no, no other publication of that work, CC BY-SA 3.0, Link
The point of a communication diagram is to illustrate the same information as a sequence diagram but in a different form. This allows a different view of the information which may enable easier finding of problems.
Structural diagrams are about how the application looks from an architectural point of view. This is more about the application looks from a code point of view than how it runs. There are seven types of structural diagram:
- Class Diagrams.
- Object Diagrams.
- Component Diagrams.
- Composite Structure Diagrams.
- Deployment Diagrams.
- Package Diagrams.
- Profile Diagrams.
Class diagrams are perhaps the most common UML diagram type seen. They visualise most of the information contained in our source code. An example class diagram is:
By No machine-readable author provided. Noodlez84 assumed (based on copyright claims). - No machine-readable source provided. Own work assumed (based on copyright claims)., Public Domain, Link
- Top layer: the name of the class.
- Middle layer: the properties or attributes of the class.
- Bottom layer: the methods of the class.
Attributes and methods are the key pieces of information for an individual class. There information provided includes:
- The visibility of the attribute or method:
+
meanspublic
.-
meansprivate
.#
meansprotected
.~
means package level visibility.
- The name of the attribute or method.
- The parameters (names and types) for method calls.
- The type of the attribute or method.
All this information is contained within your code so it is easy to create a class diagram from an existing set of code. We do this in Lab 05. The other information contained in your code is the relationships between objects:
By Yanpas - https://commons.wikimedia.org/wiki/File:Uml_classes_en.svg, CC BY-SA 4.0, Link
- association is the most generic relationship type.
- inheritance means that a class is a specialisation of another class.
- realization/implementation is when a class implements an interface.
- dependency is a special form of association where changes to a class means the dependant class will likely have to change.
- aggregation is a special form of association denoting a has-a relationship. This is not considered a strong relationship in so far as the class does not own the associated object.
- composition is as aggregation but now the class owns the object. When an instance of the owning object is destroyed so are its components.
We won't discuss association any further as this is the most generic relationship type. It means that there is some form of relationship between the two classes. The more likely relationship is a dependency. This is where one class uses another, and therefore any changes to the used class will likely require changes to the using class.
Aggregation and composition are similar relationships that illustrate that an instance of a class is an attribute of another class. The difference is in the ownership. Aggregation means that the attribute object is shared between multiple other objects. The composition relationship means that the object owns its attribute instance, and when it is destroyed so is the other object.
Aggregation and composition can also have multiplicity. This is when a number is placed on the ends of the arrows to indicate is 1, 0..1, 1..*, 0..*, etc. depending on how many of a given object is contained. The name of the relationship (i.e., attribute name) may also be provided. The following diagram illustrates a couple of different uses of aggregation and composition:
By ACiD2, Mikm, Pne, Mjchonoles, Rjgodoy - Own work, Public Domain, Link
Relationships are perhaps the most difficult aspect of object-orientation for new students. Using diagrams does enable a better understanding, if you understand what all the different relationship types mean.
Object diagrams model objects at a specific point in the execution of the software. These are object instances rather than classes. Object diagrams are not commonly used; normally only for data structures.
By Mac9 - Own work, Public Domain, Link
Component diagrams allow us to visualise how different software components (e.g., executables, libraries) work together. This can be useful if you want to see dependencies between such components, but of limited use otherwise.
By Kishorekumar 62 - Own work, CC BY-SA 3.0, Link
Composite structure diagrams are like component diagrams but take a class and class attribute point of view. This is a very low level which has limited use.
By [:w:User:KenSWebb|User:KenSWebb] - English Wikipedia here, Public Domain, Link
Deployment diagrams also examine software components and their relationships, but also include hardware nodes where these components run. This can be useful if you have a complex configuration to manage.
By Kishorekumar 62 - Own work, CC BY-SA 3.0, Link
Package diagrams illustrate how different packages interact. This can be useful if you want to see which packages in your library/application rely on each other. If this information isn't useful neither is the package diagram.
By Kishorekumar 62 - Own work, CC BY-SA 3.0, Link
Profile diagrams are well outside the scope of this module. These diagrams are about extending the existing UML notation.
By Gubaer - Own work (Original text: selbst gezeichnet), GFDL, Link
This unit has mainly been information based without much context. The second part of this unit provides a useful look at UML. Here we have:
- Defined UML and its history, especially around why it is a unified modelling approach.
- Described the fourteen UML models, dividing these into behavioural and structural types.
There are quite a few UML books available, each with their strengths and weaknesses. One that currently has good reviews is UML @ Classroom: