Understanding Object Behaviors and Statechart Diagrams in Software Design

 
O
b
j
e
c
t
 
B
e
h
a
v
i
o
u
r
s
U
M
L
 
S
t
a
t
e
c
h
a
r
t
 
D
i
a
g
r
a
m
s
 
S
o
f
t
w
a
r
e
 
R
e
q
u
i
r
e
m
e
n
t
s
 
a
n
d
 
D
e
s
i
g
n
C
I
T
S
4
4
0
1
L
e
c
t
u
r
e
 
1
1
 
B
a
s
e
d
 
o
n
 
l
e
c
t
u
r
e
 
n
o
t
e
s
 
b
y
 
B
r
u
e
g
g
e
 
&
 
D
u
t
o
i
t
 
F
i
n
i
t
e
 
s
t
a
t
e
 
m
a
c
h
i
n
e
 
flip switch on
 
flip switch off
Light off
Light on
 
U
M
L
 
S
t
a
t
e
c
h
a
r
t
 
D
i
a
g
r
a
m
s
 
A
 
U
M
L
 
s
t
a
t
e
c
h
a
r
t
 
d
i
a
g
r
a
m
 
i
s
 
a
 
n
o
t
a
t
i
o
n
 
f
o
r
 
d
e
s
c
r
i
b
i
n
g
 
t
h
e
s
e
q
u
e
n
c
e
 
o
f
 
s
t
a
t
e
s
 
a
n
 
o
b
j
e
c
t
 
g
o
e
s
 
t
h
r
o
u
g
h
 
i
n
 
r
e
s
p
o
n
s
e
 
t
o
 
e
x
t
e
r
n
a
l
e
v
e
n
t
s
.
UML state machines are extensions of the finite state machine
model.
A
 
s
t
a
t
e
 
i
s
 
a
 
c
o
n
d
i
t
i
o
n
 
s
a
t
i
s
f
i
e
d
 
b
y
 
t
h
e
 
a
t
t
r
i
b
u
t
e
s
 
o
f
 
a
n
 
o
b
j
e
c
t
.
A
 
t
r
a
n
s
i
t
i
o
n
 
i
n
d
i
c
a
t
e
s
 
a
 
m
o
v
e
 
f
r
o
m
 
o
n
e
 
s
t
a
t
e
 
t
o
 
a
n
o
t
h
e
r
A
n
 
e
v
e
n
t
 
i
s
 
a
 
p
o
t
e
n
t
i
a
l
 
t
r
i
g
g
e
r
 
f
o
r
 
a
 
c
h
a
n
g
e
 
o
f
 
s
t
a
t
e
 
S
t
a
t
e
 
m
a
c
h
i
n
e
 
flip switch on
 
flip switch off
 
State
 
Transition
 
Event
Light on
Light off
 
E
x
 
1
.
 
I
n
t
e
r
a
c
t
i
o
n
 
w
i
t
h
 
P
C
 
(
V
1
)
 
ctrl-alt-del
 
username-passwd
 
request-logout
 
confirm-logout
Blue screen
Login screen
Active
desktop
Logout
screen
 
U
M
L
 
S
t
a
t
e
c
h
a
r
t
s
 
S
t
a
t
e
 
m
a
c
h
i
n
e
 
m
o
d
e
l
s
 
s
h
o
w
 
h
o
w
 
i
n
d
i
v
i
d
u
a
l
 
o
b
j
e
c
t
s
 
c
h
a
n
g
e
 
t
h
e
i
r
s
t
a
t
e
 
i
n
 
r
e
s
p
o
n
s
e
 
t
o
 
e
v
e
n
t
s
.
 
 
T
h
e
y
 
a
r
e
 
r
e
p
r
e
s
e
n
t
e
d
 
i
n
 
t
h
e
 
U
M
L
 
u
s
i
n
g
s
t
a
t
e
c
h
a
r
t
 
d
i
a
g
r
a
m
s
 
W
h
i
l
e
 
s
e
q
u
e
n
c
e
 
d
i
a
g
r
a
m
s
 
a
r
e
 
u
s
e
d
 
t
o
 
m
o
d
e
l
 
t
h
e
 
c
o
m
b
i
n
e
d
b
e
h
a
v
i
o
u
r
 
o
f
 
a
 
g
r
o
u
p
 
o
f
 
o
b
j
e
c
t
s
 
i
n
 
t
h
e
 
s
y
s
t
e
m
,
 
t
h
e
 
s
t
a
t
e
c
h
a
r
t
d
i
a
g
r
a
m
s
 
a
r
e
 
u
s
e
d
 
t
o
 
m
o
d
e
l
 
t
h
e
 
b
e
h
a
v
i
o
u
r
 
o
f
 
a
 
s
i
n
g
l
e
 
o
b
j
e
c
t
 
i
n
r
e
s
p
o
n
s
e
 
t
o
 
e
x
t
e
r
n
a
l
 
e
v
e
n
t
s
.
 
In the context of behaviour modelling, 2 different characterizations of
states must be considered:
1.
the state of each class, and
2.
the state of the system as observed from the outside as the system
performs its function.
 
 
I
n
t
e
r
a
c
t
i
o
n
 
w
i
t
h
 
P
C
 
(
V
2
)
U
M
L
 
S
t
a
t
e
c
h
a
r
t
 
D
i
a
g
r
a
m
 
N
o
t
a
t
i
o
n
UML notation based on statecharts by Harel in 1987
Added are a  few object-oriented modifications
A UML statechart diagram (or UML state machine) can
be mapped into a finite state machine (FSM)
State2
State1
Event1(attr) [condition]/action
entry/action
exit/action
do/action
Also: internal transitions
Event trigger
With parameters
Guard
condition
event/action
 
S
t
a
t
e
c
h
a
r
t
 
D
i
a
g
r
a
m
s
 
G
r
a
p
h
s
 
w
h
o
s
e
 
n
o
d
e
s
 
a
r
e
 
s
t
a
t
e
s
 
a
n
d
 
w
h
o
s
e
 
d
i
r
e
c
t
e
d
 
a
r
c
s
 
a
r
e
 
t
r
a
n
s
i
t
i
o
n
s
l
a
b
e
l
l
e
d
 
b
y
 
e
v
e
n
t
s
.
States capture conditions which hold for a period of time
e.g. light is on, light is off
Events 
change
 the state (except internal)
e.g. turning the light on, turning the light off
Statechart diagrams represent behaviour from the perspective of a single
object only
An object model with a 
set
 of objects must be represented by a 
set 
of state
diagrams
 
S
t
a
t
e
 
An abstraction of the attributes of a class
State is the aggregation of several attributes of a class
 
Basically an equivalence class of all those attribute values
and links that do not need to be distinguished as far as the
control structure of the system is concerned
Example: State of a user interface screen
logged in, logged out, active, idle
active is an 
abstraction
 of all the user’s logged in activity
 
State has duration
 
E
v
e
n
t
 
Something that happens at a point in time (e.g. button press, mouse click)
 
Triggers a transition
Internal transition (no state change)
External transition (change to different state)
 
May result in an action being executed
 
E
x
a
m
p
l
e
 
2
:
 
v
e
n
d
i
n
g
 
m
a
c
h
i
n
e
 
Idle
 
Collect Money
 
coins_in(amount) / add to balance
 
 
 
do: test item and compute change
 
 
do: make change
 
do: dispense item
 
 
[change=0]
 
[change>0]
 
[item empty]
 
[select(item)]
 
[change<0]
 
coins_in(amount) / set balance
 
cancel / refund coins
 
 
A
n
o
t
h
e
r
 
e
x
a
m
p
l
e
 
States of the 
Incident 
object of FRIEND
incidentArchived
incidentDocumented
incidentHandled
 
P
r
o
b
l
e
m
 
S
t
a
t
e
m
e
n
t
:
D
i
r
e
c
t
i
o
n
 
C
o
n
t
r
o
l
 
f
o
r
 
a
 
T
o
y
 
C
a
r
 
Power is turned on
Car moves forward and car
headlight shines
Power is turned off
Car stops and headlight
goes out.
Power is turned on
Headlight shines
Power is turned off
Headlight goes out.
Power is turned on
Car runs backward with its
headlight shining.
 
Power is turned off
Car stops and headlight
goes out.
Power is turned on
Headlight shines
Power is turned off
Headlight goes out.
Power is turned on
Car runs forward with its
headlight shining.
 
T
o
y
 
C
a
r
:
 
D
y
n
a
m
i
c
 
M
o
d
e
l
 
P
r
a
c
t
i
c
a
l
 
T
i
p
s
 
f
o
r
 
D
y
n
a
m
i
c
 
M
o
d
e
l
i
n
g
 
Construct dynamic models only for classes with
significant dynamic behavior
Avoid “analysis paralysis”
Consider only relevant attributes
Use abstraction if necessary
Look at the granularity of the application when deciding
on actions and activities
Reduce notational clutter
 
S
t
a
t
e
 
C
h
a
r
t
 
D
i
a
g
r
a
m
 
v
s
 
S
e
q
u
e
n
c
e
 
D
i
a
g
r
a
m
 
State chart diagrams help to identify:
C
h
a
n
g
e
s
 
t
o
 
o
b
j
e
c
t
s
 
o
v
e
r
 
t
i
m
e
 
Sequence diagrams help to identify
T
h
e
 
t
e
m
p
o
r
a
l
 
r
e
l
a
t
i
o
n
s
h
i
p
s
 
b
e
t
w
e
e
n
o
b
j
e
c
t
s
 
o
v
e
r
 
t
i
m
e
S
e
q
u
e
n
c
e
 
o
f
 
o
p
e
r
a
t
i
o
n
s
 
a
s
 
a
 
r
e
s
p
o
n
s
e
 
t
o
o
n
e
 
o
r
 
m
o
r
e
 
e
v
e
n
t
s
 
 
W
h
e
n
 
t
o
 
u
s
e
 
s
t
a
t
e
 
d
i
a
g
r
a
m
s
[
F
o
w
l
e
r
]
 
S
t
a
t
e
 
d
i
a
g
r
a
m
s
 
a
r
e
 
g
o
o
d
 
a
t
 
d
e
s
c
r
i
b
i
n
g
 
t
h
e
 
b
e
h
a
v
i
o
r
 
o
f
 
a
n
 
o
b
j
e
c
t
a
c
r
o
s
s
 
s
e
v
e
r
a
l
 
u
s
e
 
c
a
s
e
s
.
State diagrams are not very good at describing behavior that
involves a number of objects collaborating.
Therefore it is useful to combine state diagrams with other
techniques.
If you do use state diagrams, don’t try to draw them for every class
in the system. … it is almost always a waste of effort.
Use state diagrams only for those classes that exhibit interesting
behaviour, where building the state diagram helps you understand
what is going on.
M
a
n
y
 
p
e
o
p
l
e
 
f
i
n
d
 
t
h
a
t
 
U
s
e
r
 
I
n
t
e
r
f
a
c
e
 
a
n
d
 
C
o
n
t
r
o
l
 
o
b
j
e
c
t
s
 
h
a
v
e
 
t
h
e
k
i
n
d
 
o
f
 
b
e
h
a
v
i
o
u
r
 
t
h
a
t
 
i
s
 
u
s
e
f
u
l
 
t
o
 
d
e
p
i
c
t
 
w
i
t
h
 
a
 
s
t
a
t
e
 
d
i
a
g
r
a
m
.
 
R
e
v
i
e
w
 
(
1
)
:
 
R
e
q
u
i
r
e
m
e
n
t
s
 
A
n
a
l
y
s
i
s
 
1. What are the transformations?
Create 
scenarios and use case diagrams
Talk to client, observe, get historical records, do thought experiments
 
 2. What is the structure of the system?
Create 
object
 and 
class diagrams
Identify objects. What are the associations between them? What is their
multiplicity?
What are the attributes of the objects?
What operations are defined on the objects?
 
Functional Modelling
 
Object Modelling
 
R
e
v
i
e
w
 
(
2
)
:
 
R
e
q
u
i
r
e
m
e
n
t
s
 
A
n
a
l
y
s
i
s
 
3. What is its control structure?
Create  
state diagrams
Only for the dynamically interesting objects.
 
Create  
sequence diagrams
Identify senders and receivers of events
Show sequence of events exchanged between objects. Identify event
dependencies and event concurrency.
 
Dynamic Modelling
 
W
h
e
n
 
i
s
 
a
 
m
o
d
e
l
 
d
o
m
i
n
a
n
t
?
 
F
u
n
c
t
i
o
n
a
l
 
m
o
d
e
l
T
h
e
 
m
o
d
e
l
 
p
e
r
f
o
r
m
s
 
c
o
m
p
l
i
c
a
t
e
d
 
t
r
a
n
s
f
o
r
m
a
t
i
o
n
s
 
s
u
c
h
 
a
s
 
d
i
f
f
i
c
u
l
t
c
o
m
p
u
t
a
t
i
o
n
s
 
c
o
n
s
i
s
t
i
n
g
 
o
f
 
m
a
n
y
 
s
t
e
p
s
.
 
O
b
j
e
c
t
 
m
o
d
e
l
T
h
e
 
s
y
s
t
e
m
 
h
a
s
 
n
o
n
-
t
r
i
v
i
a
l
 
d
a
t
a
 
s
t
r
u
c
t
u
r
e
s
.
 
D
y
n
a
m
i
c
 
m
o
d
e
l
T
h
e
 
m
o
d
e
l
 
h
a
s
 
m
a
n
y
 
d
i
f
f
e
r
e
n
t
 
t
y
p
e
s
 
o
f
 
e
v
e
n
t
s
:
 
I
n
p
u
t
,
 
o
u
t
p
u
t
,
e
x
c
e
p
t
i
o
n
s
,
 
e
r
r
o
r
s
,
 
e
t
c
.
 
W
h
e
n
 
i
s
 
a
 
m
o
d
e
l
 
d
o
m
i
n
a
n
t
?
 
E
x
a
m
p
l
e
s
 
Compiler:
 Functional model most important. Dynamic model is trivial
because there is only one type input and only a few outputs.
 
Database systems:
 Object model most important. Functional model is
trivial, because their purpose is usually only to store, organize and
retrieve data.
 
Spreadsheet program:
 Functional model most important. Object model is
trivial, because the spreadsheet values are trivial and cannot be
structured further. The only interesting object is the cell. Dynamic model
is also relatively important.
 
R
e
c
o
m
m
e
n
d
e
d
 
r
e
a
d
i
n
g
 
UML Distilled by Martin Fowler, Chapter 10
https://my.safaribooksonline.com/book/software-engineering-and-
development/uml/0321193687
 
 
“Object oriented software engineering” 
by Bruegge & Dutoit
Chapter 5
 
“Software Engineering”
  by Pressman Chapter 8, Section 8.5
Slide Note

Revised Feb 2020 RCO

Earlier Versions: RCO, DH, GMH

Embed
Share

Object behaviors and UML statechart diagrams play a crucial role in software requirements and design. State machines, transitions, events, and states are essential concepts in modeling object behavior in response to external events. By utilizing UML statechart diagrams, one can effectively represent the sequence of states an object goes through. This aids in understanding how individual objects change their state when triggered by events, thus facilitating the design of robust software systems based on defined behaviors and transitions.


Uploaded on Aug 01, 2024 | 0 Views


Download Presentation

Please find below an Image/Link to download the presentation.

The content on the website is provided AS IS for your information and personal use only. It may not be sold, licensed, or shared on other websites without obtaining consent from the author. Download presentation by click this link. If you encounter any issues during the download, it is possible that the publisher has removed the file from their server.

E N D

Presentation Transcript


  1. Object Behaviours UML Statechart Diagrams Software Requirements and Design CITS4401 Lecture 11 Based on lecture notes by Bruegge & Dutoit Department of Computer Science & Software Engineering CITS4401 Software Requirements & Design | 1

  2. Finite state machine flip switch on Light on Light off flip switch off Department of Computer Science & Software Engineering CITS4401 Software Requirements & Design | 2

  3. UML Statechart Diagrams A UML statechart diagram is a notation for describing the sequence of states an object goes through in response to external events. UML state machines are extensions of the finite state machine model. A state is a condition satisfied by the attributes of an object. A transition indicates a move from one state to another An event is a potential trigger for a change of state Department of Computer Science & Software Engineering CITS4401 Software Requirements & Design | 3

  4. State machine Transition State flip switch on Light on Light off flip switch off Event Department of Computer Science & Software Engineering CITS4401 Software Requirements & Design | 4

  5. Ex 1. Interaction with PC (V1) ctrl-alt-del Blue screen Login screen confirm-logout username-passwd Logout screen Active desktop request-logout Department of Computer Science & Software Engineering CITS4401 Software Requirements & Design | 5

  6. UML Statecharts State machine models show how individual objects change their state in response to events. They are represented in the UML using statechart diagrams While sequence diagrams are used to model the combined behaviour of a group of objects in the system, the statechart diagrams are used to model the behaviour of a single object in response to external events. In the context of behaviour modelling, 2 different characterizations of states must be considered: 1.the state of each class, and 2.the state of the system as observed from the outside as the system performs its function. Department of Computer Science & Software Engineering CITS4401 Software Requirements & Design | 6

  7. Interaction with PC (V2) Department of Computer Science & Software Engineering CITS4401 Software Requirements & Design | 7

  8. UML Statechart Diagram Notation Event1(attr) [condition]/action State1 State2 do/action event/action Event trigger With parameters Guard condition entry/action exit/action Also: internal transitions UML notation based on statecharts by Harel in 1987 Added are a few object-oriented modifications A UML statechart diagram (or UML state machine) can be mapped into a finite state machine (FSM) Department of Computer Science & Software Engineering CITS4401 Software Requirements & Design | 8

  9. Statechart Diagrams Graphs whose nodes are states and whose directed arcs are transitions labelled by events. States capture conditions which hold for a period of time e.g. light is on, light is off Events change the state (except internal) e.g. turning the light on, turning the light off Statechart diagrams represent behaviour from the perspective of a single object only An object model with a set of objects must be represented by a set of state diagrams Department of Computer Science & Software Engineering CITS4401 Software Requirements & Design | 9

  10. State An abstraction of the attributes of a class State is the aggregation of several attributes of a class Basically an equivalence class of all those attribute values and links that do not need to be distinguished as far as the control structure of the system is concerned Example: State of a user interface screen logged in, logged out, active, idle active is an abstraction of all the user s logged in activity State has duration Department of Computer Science & Software Engineering CITS4401 Software Requirements & Design | 10

  11. Event Something that happens at a point in time (e.g. button press, mouse click) Triggers a transition Internal transition (no state change) External transition (change to different state) May result in an action being executed Department of Computer Science & Software Engineering CITS4401 Software Requirements & Design | 11

  12. Example 2: vending machine coins_in(amount) / set balance Collect Money coins_in(amount) / add to balance Idle cancel / refund coins [item empty] [select(item)] [change<0] do: test item and compute change [change>0] [change=0] do: dispense item do: make change Department of Computer Science & Software Engineering CITS4401 Software Requirements & Design | 12

  13. Another example incidentDocumented incidentArchived incidentHandled States of the Incident object of FRIEND Department of Computer Science & Software Engineering CITS4401 Software Requirements & Design | 13

  14. Problem Statement: Direction Control for a Toy Car Power is turned off Car stops and headlight goes out. Power is turned on Headlight shines Power is turned off Headlight goes out. Power is turned on Car runs forward with its headlight shining. Power is turned on Car moves forward and car headlight shines Power is turned off Car stops and headlight goes out. Power is turned on Headlight shines Power is turned off Headlight goes out. Power is turned on Car runs backward with its headlight shining. Department of Computer Science & Software Engineering CITS4401 Software Requirements & Design | 14

  15. Toy Car: Dynamic Model Wheel Headlight Stationary Forward Stationary power on power off Off power power on off power off power on Stationary Stationary On power power off on Stationary Backward Stationary power on power off Department of Computer Science & Software Engineering CITS4401 Software Requirements & Design | 15

  16. Practical Tips for Dynamic Modeling Construct dynamic models only for classes with significant dynamic behavior Avoid analysis paralysis Consider only relevant attributes Use abstraction if necessary Look at the granularity of the application when deciding on actions and activities Reduce notational clutter Department of Computer Science & Software Engineering CITS4401 Software Requirements & Design | 16

  17. State Chart Diagram vs Sequence Diagram State chart diagrams help to identify: Changestoobjects over time Sequence diagrams help to identify The temporal relationships between objects over time Sequence of operations as a response to one or more events Department of Computer Science & Software Engineering CITS4401 Software Requirements & Design | 17

  18. When to use state diagrams [Fowler] State diagrams are good at describing the behavior of an object across several use cases. State diagrams are not very good at describing behavior that involves a number of objects collaborating. Therefore it is useful to combine state diagrams with other techniques. If you do use state diagrams, don t try to draw them for every class in the system. it is almost always a waste of effort. Use state diagrams only for those classes that exhibit interesting behaviour, where building the state diagram helps you understand what is going on. Many people find that User Interface and Control objects have the kind of behaviour that is useful to depict with a state diagram. Department of Computer Science & Software Engineering CITS4401 Software Requirements & Design | 18

  19. Review (1): Requirements Analysis Functional Modelling 1. What are the transformations? Create scenarios and use case diagrams Talk to client, observe, get historical records, do thought experiments 2. What is the structure of the system? Create object and class diagrams Identify objects. What are the associations between them? What is their multiplicity? What are the attributes of the objects? What operations are defined on the objects? Object Modelling Department of Computer Science & Software Engineering CITS4401 Software Requirements & Design | 19

  20. Review (2): Requirements Analysis 3. What is its control structure? Create state diagrams Only for the dynamically interesting objects. Dynamic Modelling Create sequence diagrams Identify senders and receivers of events Show sequence of events exchanged between objects. Identify event dependencies and event concurrency. Department of Computer Science & Software Engineering CITS4401 Software Requirements & Design | 20

  21. When is a model dominant? Functional model The model performs complicated transformations such as difficult computations consisting of many steps. Object model The system has non-trivial data structures. Dynamic model The model has many different types of events: Input, output, exceptions, errors, etc. Department of Computer Science & Software Engineering CITS4401 Software Requirements & Design | 21

  22. When is a model dominant? Examples Compiler: Functional model most important. Dynamic model is trivial because there is only one type input and only a few outputs. Database systems: Object model most important. Functional model is trivial, because their purpose is usually only to store, organize and retrieve data. Spreadsheet program: Functional model most important. Object model is trivial, because the spreadsheet values are trivial and cannot be structured further. The only interesting object is the cell. Dynamic model is also relatively important. Department of Computer Science & Software Engineering CITS4401 Software Requirements & Design | 22

  23. Recommended reading UML Distilled by Martin Fowler, Chapter 10 https://my.safaribooksonline.com/book/software-engineering-and- development/uml/0321193687 Object oriented software engineering by Bruegge & Dutoit Chapter 5 Software Engineering by Pressman Chapter 8, Section 8.5 Department of Computer Science & Software Engineering CITS4401 Software Requirements & Design | 23

More Related Content

giItT1WQy@!-/#giItT1WQy@!-/#giItT1WQy@!-/#giItT1WQy@!-/#giItT1WQy@!-/#giItT1WQy@!-/#giItT1WQy@!-/#giItT1WQy@!-/#giItT1WQy@!-/#giItT1WQy@!-/#