COMP 325 Lecture 12: Object Oriented Analysis: System Dynamics
major resources: Introduction to Object Oriented Analysis, Brown 2002,
Object-Oriented and Classical Software Engineering 6ed,
Schach 2005, Object-Oriented Software Engineering, Schach 2008.
[ previous
| schedule
| next
]
Modeling System Dynamics
- Any object that is created and later deleted has a life cycle (born-lives-dies).
- So far we have focused on static aspects of an object, now turn to dynamics
(what happens over time)
- object diagram includes only static aspects of the system
- dynamics are modeled in UML using
- statechart diagrams
- collaboration diagrams
- sequence diagrams
- In Schach OOA, this addresses dynamic modeling and use-case realization
- In Brown OOA, this addresses KRB Step 7 find behaviors
UML Statechart diagrams
- Any object that has attributes has state (set of attribute values).
- Any object having behaviors/associations which change its attributes can
undergo state transitions.
- State transition occurs when object state changes
- State transitions are triggered by events.
- Many object state transitions are of interest for analysis modeling - in
particular, those that model changes of state that user's-world object goes
through. Others occur but are not yet of interest.
- Statechart diagrams (similar to state transition diagrams or finite
state machines) are included in UML to model life cycles and state transitions.
- class should probably have a statechart diagram if it has an
operational life cycle (pattern repeated many times throughout life,
such as states of a library book: shelved -> checked out -> checked
in -> shelved).
- What kinds of things are relevant to the "experience" of changing
state?
- the source state, or state before the transition
- the target state, or state after the transition
- the event trigger, or event that directly causes the transition
- the guard condition, an optional condition that must be true
at the time event is received for the transition to occur
- the transition action, an optional and atomic operation carried
out "during" the transition
- Some Examples
- Operation of an elevator
- consider single elevator system, such as in Towers Hall
- what states does it have?
- what events cause state transitions, and from what to what?
- what events (if any) do not cause state transition?
- develop a UML statechart diagram
- note that this is an operational cycle, not a life cycle
- Operation of a credit-card gasoline pump
- Operation of an ATM machine (consider 3 classes: customer, machine, account DB)
- Basic symbols (from
http://www.smartdraw.com/tutorials/software-uml/uml5.htm):
state |
data:image/s3,"s3://crabby-images/09ac6/09ac65b59d38e681dcb48f1935073c0e7838fda5" alt="" |
event-driven transition |
data:image/s3,"s3://crabby-images/4edf9/4edf98b8a260a95c8b5651d71f215fa2b5684fe6" alt="" |
initial state |
data:image/s3,"s3://crabby-images/9198b/9198b480c5b5a82079668346ae7089be742c2403" alt="" |
final state |
data:image/s3,"s3://crabby-images/c6cfd/c6cfd97591fc08967662623f93149e8d91557775" alt="" |
data:image/s3,"s3://crabby-images/e6133/e61336060db475ba28ed2367b887df0348ec3da0" alt=""
Statechart Diagram for Logging into online banking service
UML Collaboration diagrams
- Class diagrams and statecharts do not accurately model execution sequences
- a CRC card models associations and collaborations with other classes from
the viewpoint of one class but not dynamics
- a class diagram models associations among all classes in the diagram but
not dynamics
- a statechart models class and object dynamics (not associations), but only
partially models sequence
- the UML tools to model sequence are collaboration diagrams
and sequence diagram
- Collaboration diagram is comparable in power to sequence diagram (see below) for illustrating dynamics,
except sequence must be made explicit by numbering arrows.
- Basic symbols (from
http://www.smartdraw.com/tutorials/software-uml/uml5.htm):
Object and/or class (do not include attributes) can use stereotype figure or stick person |
data:image/s3,"s3://crabby-images/eb9e9/eb9e9f7c1edd2c272380fb734e90f64db5bcbddf" alt="" |
message passing (method invocation) include sequence number optional condition in [ ] |
data:image/s3,"s3://crabby-images/81927/81927c866c02fea67b6aa040596cf699cbba06cc" alt="" |
Association between classes |
data:image/s3,"s3://crabby-images/a5742/a57422eab175c27dfb2978fe2ab4e3f1bb338f78" alt="" |
data:image/s3,"s3://crabby-images/0c096/0c0964758ae58679757d162ee9ea6c830e66bd39" alt=""
Collaboration Diagram for Elevator Button
UML Sequence diagrams
- What a sequence diagram shows
- diagram represents an execution sequence from the viewpoint of one class
- can be developed during use-case role playing exercise (at same time as
CRC cards are developed)
- viewpoint is typically that of a "client" class which requests things from
other classes
- a 2-dimensional chart
- leftmost "column" is client class
- other "columns" represent classes that it interacts with
- each "row" represents an interaction (event, message, response)
- rows are time ordered from top (first interaction) to bottom (last interaction)
-- relative length of time is not modeled
- To see examples of sequence diagrams on the web, search for "uml sequence
diagram"
- See http://www.agilemodeling.com/style/sequenceDiagram.htm for some examples
Object and/or class (do not include attributes) |
data:image/s3,"s3://crabby-images/bf113/bf11332efa96b4e70311f949ab7b6a5c76a4f69b" alt="" |
Actor (other stereotype figures can be used) |
data:image/s3,"s3://crabby-images/9567e/9567eb571b48c5f8ed2c8c4e7fdf28b2cab33d29" alt="" |
Object lifeline (starts when created) |
data:image/s3,"s3://crabby-images/4a034/4a034eb7b4eef65f1675319b89f3baa2f0ea4b26" alt="" |
Active section of timeline |
data:image/s3,"s3://crabby-images/ffc71/ffc71de559036b0fbc39abe82a0a0e036de12d1e" alt="" |
Object destruction (X at lifeline bottom) |
data:image/s3,"s3://crabby-images/a99a6/a99a6158c4ce92254aa19f5571dcbfde76001977" alt="" |
message passing (method invocation) |
data:image/s3,"s3://crabby-images/09149/09149936f67d024c7a9d0af10df9d631b6ddb6e6" alt="" |
data:image/s3,"s3://crabby-images/98c19/98c1922706c04212d12248b631b0eb88e24fb4a2" alt=""
Sequence Diagram for Elevator Button
[ COMP 325
| Peter Sanderson
| Math Sciences server
| Math Sciences home page
| Otterbein
]
Last updated:
Peter Sanderson (PSanderson@otterbein.edu)