UML Tutorial for Beginners
Blog containing resources for uml like lecture notes, lecture videos, lab manual, uml diagrams, objective bits, important questions and more.

11/08/2013 Categories: Behavioral Modeling. 1 Comment on Activity Diagrams



An activity diagram is like a flowchart, representing flow of control from activity to activity, whereas, the interaction diagrams focus on the flow of control from object to object.


Activities result in some action, which is made up of executable atomic computations that result in a change of state of the system or the return of a value.


Actions involve calling another operation, sending a signal, creating or destroying an object or some pure computation, such as evaluating an expression.


Common Properties


An activity diagram shares the same common properties as do all other UML diagrams like a name which is used to uniquely identify the diagram and the graphical content which is a projection into the model.




Activity diagrams mainly contain:

  • Activity states and action states
  • Transitions
  • Objects


Action States and Activity States


Activity diagram may represent actions which are atomic computations. These atomic computations are called action states because they are states of the system, each representing the execution of an action.


In UML, an action states is represented using a lozenge symbol (rounded rectangle) as shown below:


action state example


In contrast, activity states can be further decomposed, their activity being represented by other activity diagrams. Activity states are non-atomic and can be interrupted, considered to take some duration to complete.


There is no difference in the notation of activity states and action states except that the activity states may have additional information like entry and exit actions as shown below:


activity state exampe




When the action or activity completes, the flow of control passes immediately to the next action or activity state. This flow is represented as transitions to show the path from one action or activity state to the next action or activity state.


In UML, a transition is represented as a simple directed line.


state transitions


A flow of control has to start and end someplace. Therefore, as shown in the above figure, we can specify the initial state (solid ball) and stop state (a solid ball inside a hollow circle).




Like in flowcharts, we can include a branch, which specifies alternate paths taken based on some Boolean expression which is also known as a guard condition. In UML, a branch is represented as a diamond.


A branch may have one incoming transition and two or more outgoing transitions. Across all these outgoing transitions, guards should not overlap, but they should cover all possibilities.

control flow branching


Forking and Joining


While modeling flow of control, it is common to encounter flows that are concurrent or parallel. In UML, a synchronization bar is used to specify the forking and joining of these parallel flows of control. A synchronization bar is represented as a thick vertical or horizontal line.


A fork may have one incoming transition and two or more outgoing transitions, each of which represents an independent flow of control. Below the fork, the activities in each flow carry out in parallel.


A join represents the synchronization of two or more concurrent flows of control. A join may have two or more incoming transitions and one outgoing transition. At the join, all the concurrent flows synchronize, meaning that each flow waits for the other to join and continues on below the join.

fork and joins uml




In activity diagrams, the activity states can be divided into logical groups, each group representing the object responsible for the activities. In UML, each group is known as a swimlane because, visually, each group is divided from its neighbor by a vertical solid line as shown in the below figure.


Each swimlane has its own name. In an activity diagram partitioned into swimlanes, every activity belongs to exactly one swimlane, but transitions may cross lanes.


uml swimlanes


Common Uses


When modeling the dynamic aspects of a system, you’ll use activity diagrams in two of the following ways:

  1. To model a workflow
  2. To model an operation


Common Modeling Techniques


Modeling a Workflow


To model a workflow:

  1. Establish a focus for the workflow.
  2. Select the objects that have the high-level responsibilities for parts of the overall workflow. Create a swimlane for each of these objects.
  3. Identify the pre-conditions of the workflow’s initial state and the post-conditions of the workflow’s final state.
  4. Starting at the workflow’s initial state layout the actions and activities that take place and render them as actions states or activity states.
  5. For complex actions, or for sets of actions that appear multiple times, collapse them into activity states and provide a separate activity diagram for them.
  6. Connect the action and activity states by transitions. Consider branching and then consider forking and joining.
  7. If there are important objects that are involved in the workflow, render them in the activity diagram as well.


modeling a workflow


Modeling an operation


To model an operation:

  1. Collect the abstractions involved in an operation like: parameters, attributes of the enclosing class and the neighboring class.
  2. Identify the operation’s pre-conditions and the operation’s post-conditions.
  3. Beginning at the operation’s initial state, define the actions and activities and render them as action states and activity states respectively.
  4. Use branching as necessary to specify conditional paths and iteration.
  5. If this operation is owned by an active class, use forking and joining as necessary to specify parallel flows of control.


modeling an operation

Related Links:

Popular Posts:

Note: Do you have a question on this article or have a suggestion to make this article better? You can ask or suggest us by filling in the below form. After commenting, your comment will be held for moderation and will be published in 24-48 hrs.

1 Comment

You can follow any responses to this entry through the RSS 2.0 feed.

Please find this comprehensive activity diagram tutorial with examples for further learning. There are templates that you can edit straightaway to get started.

Leave a Reply

Your email address will not be published. Required fields are marked *

Scroll Up