Download presentation
Presentation is loading. Please wait.
Published byAmie Snow Modified over 8 years ago
1
UML Fundamental Elements
2
Structural Elements Represent abstractions in our system. Elements that encapsulate the system's set of behaviors. Structural elements: – Java-independent entities, which are elements that don't have a Java language mapping. – Java-dependent entities, which are elements that have a straightforward Java mapping.
3
Java-Independent Entities Actor Use Case Collaboration Object
4
Actor An actor: – Represents a role that a user of the system plays. – Always is external to the system under development. – Need not always be a person. – Might be another external system, such as a legacy mainframe from which we are obtaining data, or possibly a device, which we must obtain data from, such as a keypad on an ATM machine.
5
Use Case A use case represents a sequence of actions that a software system guarantees to carry out on behalf of an actor. When defining use cases, the level of granularity becomes important. Use case should always provide a result of an observable value to an actor. Primary business processes typically are good candidates for use cases. A use case should be focused on the system from a customer's perspective.
6
Example of Use Case Diagram
7
Collaboration Collaborations most often are used to bring structure to our design model. They enable us to create sequence and class diagrams that work in conjunction with each other, to provide an object-oriented view into the requirements that our system satisfies. A collaboration typically has a one-to-one mapping to a use case. A collaboration models same set of requirements from a developer's perspective.
8
Example of Collaboration
9
Object An object is an instance of a class. It is represented by a rectangle. An object can also be thought of as a physical entity, whereas a class is a conceptual entity.
10
Java-Dependent Entities Class Package Interface
11
Class A class is a blueprint for an object. A class has three compartments. – The first represents the name of the class as defined in Java. – The second represents the attributes (instance variables). – The third compartment represents methods on the class. Attributes and operations can be preceded with a visibility adornment. – (+) indicates public visibility, and a – (-) denotes private visibility. – (#) denotes protected visibility. – Underlined, it indicates that it's static.
12
Example of Class Diagram
13
Package A general purpose grouping mechanism, packages can contain any other type of element. A package in the UML translates directly into a package in Java. In Java, a package can contain other packages, classes, or both. A package has a name that uniquely identifies it.
14
Example of Package Diagram
15
Interface An interface is a collection of operations that specify a service of a class. An interface translates directly to an interface type in Java. An interface can be represented either by the previously shown icon or by a regular class with a stereotype attachment of >. An interface typically is shown on a class diagram as having realization relationships with other classes.
16
Example of Interface
17
Java-Dependent Relationships Some of the relationships appear on diagrams in the structural category, most likely class diagrams. Though some, such as association, also appear on use case diagrams.
18
Dependency A "using" relationship between entities that implies a change in specification of one entity may affect the entities that are dependent upon it. A dependency translates to any type of reference to a class or object that doesn't exist at the instance scope, including a local variable, reference to an object obtained via a method call, or reference to a class' static method, where an instance of that class does not exist. A dependency also is used to represent the relationship between packages.
19
Example of Dependency
20
Association A structural relationship between entities specifying that objects are connected. The arrow is optional and specifies navigability. No arrow implies bidirectional navigability An instance of an association is a link, which is used on interaction diagrams to model messages sent between objects. In Java, an association translates to an instance scope variable.
21
Example of Association In the following example, an Employee can have 0 or more TimeCard objects. However, a TimeCard belongs to a single Employee.
22
Aggregation An aggregiation implies that the whole is at a conceptually higher level than the part. An association implies both classes are at the same conceptual level. An aggregation also implies that no cycles are in the instance graph an aggregation must be a unidirectional relationship. If you are unsure as to when to use an association or an aggregation, use an association an aggregation need not be used often.
23
Example of Aggregation
24
Generalization Illustrating a relationship between a more general element and a more specific element, a generalization is the UML element to model inheritance. In Java, a generalization directly translates into use of the extends keyword. A generalization also can be used to model relationships between actors and use cases.
25
Example of Generalization
26
Realization A relationship that specifies a contract between two entities, in which one entity defines a contract that another entity guarantees to carry out. When modeling Java applications, a realization translates directly into the use of the implements keyword. A realization also can be used to obtain traceability between use cases, which define the behavior of the system, to the set of classes that guarantee to realize this behavior.
27
Example of Realization
Similar presentations
© 2025 SlidePlayer.com. Inc.
All rights reserved.