1 / 19

UML: Unified Modeling Language

UML: Unified Modeling Language. L. Grewe. History. Graphic modeling language for describing object-oriented software Started in 1994 Combined notations from 3 leading OO methods OMT (James Rumbaugh) OOSE (Ivar Jacobson) Booch (Grady Booch) Industry standard. Why UML?.

Télécharger la présentation

UML: Unified Modeling Language

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. UML: Unified Modeling Language L. Grewe

  2. History • Graphic modeling language for describing object-oriented software • Started in 1994 • Combined notations from 3 leading OO methods • OMT (James Rumbaugh) • OOSE (Ivar Jacobson) • Booch (Grady Booch) • Industry standard

  3. Why UML? • Software larger & complex • Difficult to analyze • Describe SW clearly • Use Computer-aided software engineering (CASE) tools • A picture is worth a thousand words…..save time looking at and making visuals.

  4. What is UML? • Specify & Visualize Software via modeling language • views • diagrams • relationships between classes

  5. UML Concepts • Use case diagrams/studies • Class Diagrams • Instance Snapshots • Sequence Diagrams • ….more (for complete understanding of UML take our SW Engineering course)

  6. UML Concepts….more State Diagrams State Diagrams Class Diagrams Use Case Diagrams Use Case Diagrams State Diagrams Use Case Diagrams State Diagrams Use Case Diagrams Object Diagrams Use Case Diagrams Sequence Diagrams Scenario Diagrams State Diagrams Scenario Diagrams State Diagrams Component Diagrams Collaboration Diagrams Models Component Diagrams Scenario Diagrams Component Diagrams Scenario Diagrams Deployment Diagrams Statechart Diagrams Activity Diagrams

  7. UML: Use case study • Use Case Studies to understand system and the stakeholders & requirements. • Uses concept of Actors: • Often serves some kind of role in the SW system. (e.g. customer, vendor, etc.) • Define State & Operations for each Actor • Define Relationships between Actors

  8. Use Case Diagram • Shows actors, entities and actions involved in one usage scenario • Have a diagram and often corresponding description • Can (often) have more than one for a software program

  9. Example: Use Case Diagram use case: buy_thing participants: (Purchaser, Vendor, Thing) pre-condition: vendor.possessions -> includes thing purchaser.pocket >= thing.price post-condition: vendor.possessions = vendor.possessions - thing purchaser.possessions = purchaser.possessions + thing vendor.till = vendor.till@pre + thing.price purchaser.pocket = purchaser.pocket@pre - thing.price

  10. UML: Class Diagrams • Classes are Graphically Represented with areas for • Class Name, Class Variables, and Operations • Properties, Responsibilities, Rules, Modification History, etc.

  11. Example: Class Diagram • BookTitle class • BookTitle Instance

  12. Another Example: Class Diagrams • Here show class diagrams and associations between the classes. • Associations (diamonds/arrows) show aggregations/ compositions • See class webiste and reading for more details. • Classes: Company, Department, Office, Headquarters, Person, ContractInformation, PersonalRecord

  13. Class Diagrams: relationships Between Classes OR • Association • Permanent, structural, “has a” • Solid line (arrowhead optional) • Dependency • Temporary, “uses a” • Dotted line with arrowhead • Generalization • Inheritance, “is a” • Solid line with open (triangular) arrowhead • Implementation • Dotted line with open (triangular) arrowhead

  14. Associations w/ Navigation Information • Can indicate direction of relationship • Represented by solid line with arrowhead Gas Pedal class knows about Engine class Engine class doesn’t know about Gas Pedal class

  15. Cardinality of Associations • Some relationships may be quantified • Cardinality denotes how many objects the source object can legitimately reference • Examples • *  0, 1, or more • 5  5 exactly • 5..8  between 5 and 8, inclusive • 5..*  5 or more

  16. Example: cardinality • Says : Bank to Branch is a 1 to many association….means a Bank can have many Branches, but, a Branch is associated with one Bank.

  17. UML Instance Snapshot • Diagram that shows results of applying a use-case action.

  18. UML Use Case Sequence Diagram • Scenario shows the sequence of events in a use-case. • Here the use-case is ian applying for a job, where tony is the secretary and sue is the manager.

  19. Generalization • Denotes inheritance between classes • Can view as “is-a” relationship • Represented by line ending in (open) triangle Laptop, Desktop, PDA inherit state & behavior from Computers

More Related