Modeling behavior with UML State Machines
Introduction
every object has finite set of states during life.
state machine diagram is used to:
- model possible states of system/object
- show how state transitions occur as consequence of events
- show behavior of system in each state
data:image/s3,"s3://crabby-images/6d426/6d4267e1207a61bd7b08617f32952ccf82dc3509" alt="Simple example"
States
states are the nodes of state machine
when a state is active:
- object is in that state
- all internal activities in that state can be executed:
entry/Activity
- when object enters the state
do/Activity
- while object remains in this state
exit/Activity
- when object exits the state
Transitions
change from one state to another
data:image/s3,"s3://crabby-images/2475a/2475a0b4c145a0099e23e6bb353532089d38cba4" alt="Transition diagram"
Syntax of transitions:
data:image/s3,"s3://crabby-images/fa710/fa7100b3a3c82a2acd8fcafbb8a9e937ca8169e7" alt="Syntax of transitions"
- Event (trigger)
- can trigger state transition
- Guard (condition)
- boolean expression
- if event occurs, guard is checked
- if guard is true:
- all activities in current state are terminated
- exit activity is executed
- transition happens
- Activity (effect)
- sequence of actions that happen during transition
Types:
-
internal:
data:image/s3,"s3://crabby-images/35b6e/35b6e1bc37668616497847d72a0cb2596f5dbb55" alt="Internal state transition"
- if
event1
happens, object stays in state1
and Activity3
runs
-
external:
data:image/s3,"s3://crabby-images/55b25/55b25bcb901e9ec47b160a73d3bea4089fa73b3e" alt="External state transition"
- if
event1
happens:
- object leaves
state1
, Activity2
runs
Activity3
runs
- object enters
state1
and Activity1
runs
Timing of transitions:
data:image/s3,"s3://crabby-images/14fa0/14fa0c7e8e60016d53b508d3720cc860bc07811c" alt="Table of transition timing"
Types of events
- Signal event: receipt of a signal (
rightmousedown
, sendSMS(message)
)
- Call event: operation call (
occupy(user, lectureHall)
, register(exam)
)
- Time event: time-based state transition (relative or absolute time)
- Any receive event: when any event occurs that doesn’t trigger another transition from the active state
- Completion event: automatic when everything is completed in the current state
- Change event: permanently checking when a condition becomes true
A change event is permanently checked. A guard is only checked when the event occurs.
Types of states
Initial state:
- “start” of the diagram
- pseudo-state, system can’t remain in this state
- no incoming edges
- outgoing edges have to be mutually exclusive and at least one target must be reachable. no events allowed.
- system immediately switches from initial state.
- notation:
data:image/s3,"s3://crabby-images/774cc/774cc316ec9e4181edec3ef2aa0c3af566c56ea8" alt="Initial state notation"
Final state:
- real state
- end of sequence of states
- can remain in this state forever
- notation:
data:image/s3,"s3://crabby-images/e6908/e690836f34e4ec3b8e4e7becbe368e5e08cac437" alt="Final state notation"
Terminate node:
- pseudo-state
- terminates state machine
- modeled object is deleted
- notation:
data:image/s3,"s3://crabby-images/321de/321de6e67c4d6ec57edbb83ceb6d3d231224cd36" alt="Terminate node notation"
Decision node:
- pseudo-state
- used for alternative transitions
- notation:
data:image/s3,"s3://crabby-images/d1070/d10703355e01126ac42db7069c009e65e4b30401" alt="Decision node notation"
Parallelization node:
- pseudo-state
- splits control flow into multiple concurrent flows
- 1 incoming edge, >1 outgoing edges
- notation:
data:image/s3,"s3://crabby-images/39d1e/39d1ec39a2f153629c8adab33ead2df4d4fa4475" alt="Parallelization node notation"
Synchronization node:
- pseudo-state
- merges multiple concurrent flows
-
1 incoming edge, 1 outgoing edge
- notation:
data:image/s3,"s3://crabby-images/1ba10/1ba1044044c798d1d2f25cfefb7c121f9e45a5bc" alt="Synchronization node notation"
Composite state:
- contains substates, with only one of them active at any time
- arbitrary nesting depth
- higher level events take priority
data:image/s3,"s3://crabby-images/4e39f/4e39fbb0f85e3ca55ffe73f2ba24d8d4a221a092" alt="Composite state diagram"
Orthogonal state:
- composite state divided into two or more regions, separated by dashed line
- one state of each region is always active at some point (concurrent substates)
- final state has to be reached in all regions to trigger completion
data:image/s3,"s3://crabby-images/29a0d/29a0d97666af186b54367d3244305da3ccbdb576" alt="Orthogonal state diagram"
Submachine state (SMS)
- to reuse parts of state machine diagrams in other ones
- as soon as submachine state is activated, behavior of submachine is executed (subroutine)
- notation:
state:submachineState
data:image/s3,"s3://crabby-images/f3406/f340661bf588812656c71933be7286f55a55a194" alt="Submachine state diagram"
History state:
- remembers the last active substate of a composite state
- activates ‘old’ substate and all entry activities run sequentially from outside to inside of composite state
- exactly one outgoing edge of history state points to a substate. used if the composite state was never active, or it was exited via final state.
- shallow history state restores state on the same level of the composite state (
H
)
- deep history state restores last active substate over all levels (
H*
)
Entry and exit points
Encapsulation mechanism: a composite state shall be entered/exited via a state other than initial and final states.
external transition must/need not know structure of composite state.