1 / 71

Introduction to UML

UML, or Unified Modeling Language, is a graphical notation and modeling language used to express and design software systems. It is an open standard and can be used across the entire software development lifecycle. This article provides a brief history of UML, its contributions, and an overview of UML models, views, and diagrams.

justinec
Download Presentation

Introduction to UML

An Image/Link below is provided (as is) to download presentation Download Policy: Content on the Website is provided to you AS IS for your information and personal use and may not be sold / licensed / shared on other websites without getting consent from its author. Content is provided to you AS IS for your information and personal use only. Download presentation by click this link. While downloading, if for some reason you are not able to download a presentation, the publisher may have deleted the file from their server. During download, if you can't get a presentation, the file might be deleted by the publisher.

E N D

Presentation Transcript


  1. Introduction to UML CSCE A222

  2. What is UML? • Unified Modeling Language • OMG Standard, Object Management Group • Based on work from Booch, Rumbaugh, Jacobson • UML is a modeling language to express and design documents, software • Particularly useful for OO design • Not a process, but some have been proposed using UML • Independent of implementation language

  3. Why use UML • Open Standard, Graphical notation for • Specifying, visualizing, constructing, and documenting software systems • Language can be used from general initial design to very specific detailed design across the entire software development lifecycle • Increase understanding/communication of product to customers and developers • Support for diverse application areas • Support for UML in many software packages today (e.g. Visual Studio, plugins for popular IDE’s like NetBeans, Eclipse) • Based upon experience and needs of the user community

  4. Brief History • Inundated with methodologies in early 90’s • Booch, Jacobson, Yourden, Rumbaugh • Booch, Jacobson merged methods 1994 • Rumbaugh joined 1995 • 1997 UML 1.1 from OMG includes input from others, e.g. Yourden • UML v2.5 current version

  5. History of UML

  6. Contributions to UML

  7. UML Models, Views, Diagrams • UML is a multi-diagrammatic language • Each diagram is a view into a model • Diagram presented from the aspect of a particular stakeholder • Provides a partial representation of the system • Is semantically consistent with other views • Example views

  8. Models, Views, Diagrams

  9. UML: First Pass • You can model 80% of most problems by using about 20 % UML • We only cover the 20% here

  10. UML Baseline • Use Case Diagrams • Class Diagrams • Package Diagrams • Interaction Diagrams • Sequence • Collaboration • Activity Diagrams • State Transition Diagrams • Deployment Diagrams

  11. Used during requirements elicitation to represent external behavior Actors represent roles, that is, a type of user of the system Use cases represent a sequence of interaction for a type of functionality; summary of scenarios The use case model is the set of all use cases. It is a complete description of the functionality of the system and its environment Passenger PurchaseTicket Use Case Diagrams

  12. An actor models an external entity which communicates with the system: User External system Physical environment An actor has a unique name and an optional description. Examples: Passenger: A person in the train GPS satellite: Provides the system with GPS coordinates Passenger Actors

  13. A use case represents a class of functionality provided by the system as an event flow. A use case consists of: Unique name Participating actors Entry conditions Flow of events Exit conditions Special requirements PurchaseTicket Use Case

  14. Name:Purchase ticket Participating actor:Passenger Entry condition: Passenger standing in front of ticket distributor. Passenger has sufficient money to purchase ticket. Exit condition: Passenger has ticket. Event flow: 1. Passenger selects the number of zones to be traveled. 2. Distributor displays the amount due. 3. Passenger inserts money, of at least the amount due. 4. Distributor returns change. 5. Distributor issues ticket. Use Case Diagram: Example Anythingmissing? Exceptional cases!

  15. <<extends>> relationships represent exceptional or seldom invoked cases. The exceptional event flows are factored out of the main event flow for clarity. Use cases representing exceptional flows can extend more than one use case. The direction of a <<extends>> relationship is to the extended use case Passenger PurchaseTicket <<extends>> OutOfOrder TimeOut <<extends>> <<extends>> <<extends>> Cancel NoChange The <<extends>> Relationship

  16. <<includes>> relationship represents behavior that is factored out of the use case. <<includes>> behavior is factored out for reuse, not because it is an exception. The direction of a <<includes>> relationship is to the using use case (unlike <<extends>> relationships). Passenger PurchaseMultiCard PurchaseSingleTicket <<includes>> <<includes>> NoChange Cancel CollectMoney <<extends>> <<extends>> The <<includes>> Relationship

  17. Use Cases are useful for… • Determining requirements • New use cases often generate new requirements as the system is analyzed and the design takes shape. • Communicating with clients • Their notational simplicity makes use case diagrams a good way for developers to communicate with clients. • May require some explanation. • Generating test cases • The collection of scenarios for a use case may suggest a suite of test cases for those scenarios.

  18. Use Case Diagrams: Summary • Use case diagrams represent external behavior • Use case diagrams are useful as an index into the use cases • Use case descriptions provide meat of model, not the use case diagrams. • All use cases need to be described for the model to be useful.

  19. Use Case Exercise • Create use cases for buying a beverage from the eXpress coffee shop in EIB.

  20. Class Diagrams • Gives an overview of a system by showing its classes and the relationships among them. • Class diagrams are static • they display what interacts but not what happens when they do interact • Also shows attributes and operations of each class • Good way to describe the overall architecture of system components

  21. Class Diagram Perspectives • We draw Class Diagrams under three perspectives • Conceptual • Software independent • Language independent • Specification • Focus on the interfaces of the software • Implementation • Focus on the implementation of the software

  22. TariffSchedule TariffSchedule TariffSchedule Table zone2price Enumeration getZones() Price getPrice(Zone) zone2price getZones() getPrice() Classes – Not Just for Code Name Signature Attributes Operations • A class represent a concept • A class encapsulates state (attributes) and behavior (operations). • Each attribute has a type. • Each operation has a signature. • The class name is the only mandatory information.

  23. tarif_1974:TariffSchedule Instances zone2price = { {‘1’, .20},{‘2’, .40}, {‘3’, .60}} • An instance represents a phenomenon. • The name of an instance is underlined and can contain the class of the instance. • The attributes are represented with their values.

  24. UML Class Notation • A class is a rectangle divided into three parts • Class name • Class attributes (i.e. data members, variables) • Class operations (i.e. methods) • Modifiers • Private: - • Public: + • Protected: # • Static: Underlined (i.e. shared among all members of the class) • Abstract class: Name in italics

  25. UML Class Notation • Lines or arrows between classes indicate relationships • Association • A relationship between instances of two classes, where one class must know about the other to do its work, e.g. client communicates to server • indicated by a straight line or arrow • Aggregation • An association where one class belongs to a collection, e.g. instructor part of Faculty • Indicated by an empty diamond on the side of the collection • Composition • Strong form of Aggregation • Lifetime control; components cannot exist without the aggregate • Indicated by a solid diamond on the side of the collection • Inheritance • An inheritance link indicating one class a superclass relationship, e.g. bird is part of mammal • Indicated by triangle pointing to superclass

  26. Binary Association Binary Association: Both entities “Know About” each other myB.service(); myA.doSomething();

  27. Unary Association A knows about B, but B knows nothing about A Arrow points in direction of the dependency myB.service();

  28. Aggregation Aggregation is an association with a “collection-member” relationship Hollow diamond on the Collection side No sole ownership implied void doSomething() aModule.service();

  29. Composition Composition is Aggregation with: Lifetime Control (owner controls construction, destruction) Part object may belong to only one whole object members[0] = new Employee(); … delete members[0]; Filled diamond on side of the Collection

  30. Inheritance Standard concept of inheritance Base Class Derived Class class B() extends A …

  31. UML Multiplicities Links on associations to specify more details about the relationship

  32. UML Class Example

  33. Employee Team - group - Name : string - members : Employee - individual + ID : long # Salary : double 1 - adfaf : bool * + getName () : string + setName () - calcInternalStuff ( in x : byte , in y : decimal ) Association Details • Can assign names to the ends of the association to give further information

  34. Class Exercise • Create class diagrams for eXpress scenario.

  35. Class Exercise • Create class diagrams for the Alien exercise.

  36. Static vs. Dynamic Design • Static design describes code structure and object relations • Class relations • Objects at design time • Doesn’t change • Dynamic design shows communication between objects • Similarity to class relations • Can follow sequences of events • May change depending upon execution scenario • Called Object Diagrams

  37. Object Diagrams • Shows instances of Class Diagrams and links among them • An object diagram is a snapshot of the objects in a system • At a point in time • With a selected focus • Interactions – Sequence diagram • Message passing – Collaboration diagram • Operation – Deployment diagram

  38. Object Diagrams • Format is • Instance name : Class name • Attributes and Values • Example:

  39. Objects and Links Can add association type and also message type

  40. Package Diagrams • To organize complex class diagrams, you can group classes into packages. A package is a collection of logically related UML elements • Notation • Packages appear as rectangles with small tabs at the top. • The package name is on the tab or inside the rectangle. • The dotted arrows are dependencies. One package depends on another if changes in the other could possibly force changes in the first. • Packages are the basic grouping construct with which you may organize UML models to increase their readability

  41. Package Example DispatcherInterface Notification IncidentManagement

  42. More Package Examples

  43. Interaction Diagrams • Interaction diagrams are dynamic -- they describe how objects collaborate. • A Sequence Diagram: • Indicates what messages are sent and when • Time progresses from top to bottom • Objects involved are listed left to right • Messages are sent left to right between objects in sequence

  44. Sequence Diagram Format Actor from Use Case Objects 1 2 Activation 3 4 Calls = Solid Lines Returns = Dashed Lines Lifeline

  45. Sequence Diagram : Destruction Shows Destruction of b (and Construction)

  46. Sequence Diagram : Timing Slanted Lines show propagation delay of messages Good for modeling real-time systems If messages cross this is usually problematic – race conditions

  47. Sequence Example: Alarm System • When the alarm goes off, it rings the alarm, puts a message on the display, notifies the monitoring service

  48. Sequence Diagram Example Hotel Reservation

  49. Sequence Exercise • Create a sequence diagrams for the eXpress example.

  50. Collaboration Diagram • Collaboration Diagrams show similar information to sequence diagrams, except that the vertical sequence is missing. In its place are: • Object Links - solid lines between the objects that interact • On the links are Messages - arrows with one or more message name that show the direction and names of the messages sent between objects • Emphasis on static links as opposed to sequence in the sequence diagram

More Related