Bài giảng Phân tích thiết kế phần mềm: Chương 6 - Trường ĐH Ngoại ngữ - Tin học TP.HCM
lượt xem 11
download
Bài giảng Phân tích thiết kế phần mềm: Chương 6 cung cấp cho người đọc những kiến thức như: Tương tác và đối tác tương tác; các mảnh kết hợp; hơn nữa các yếu tố ngôn ngữ; các loại sơ đồ tương tác khác. Mời các bạn cùng tham khảo!
Bình luận(0) Đăng nhập để gửi bình luận!
Nội dung Text: Bài giảng Phân tích thiết kế phần mềm: Chương 6 - Trường ĐH Ngoại ngữ - Tin học TP.HCM
- 2/28/2019 Content Introduction Interactions and interaction partners Messages Combined fragments Branches and loops Concurrency and order Filters and assertions Further language elements Further types of interaction diagrams 2 1 Introduction Interaction Diagrams Modeling inter-object behavior (mô hình hóa hành vi giữa các objs) Dùng để biểu diễn tương tác = interactions between objects Mô hình hóa các kịch bản chắc chắn Interaction (tương tác) Mô tả chuỗi giao tiếp ở các mức độ chi tiết khác nhau Specifies how messages and data are exchanged between interaction partners Interaction Diagrams show the following: Interaction partners (đối tượng tương tác) Giao tiếp giữa 1 hệ thống và môi trường Human (lecturer, administrator, …) Giao tiếp giữa các thành phần của hệ thống để thể hiện cách một use Non-human (server, printer, executable software, …) case có thể hiện thực Examples of interactions Giao tiếp giữa các tiến trình trong đó các thành tố thực hiện một giao Conversation between persons thức. Message exchange between humans and a software system Giao tiếp giữa các cấp lớp (phép gọi hàm, hành vi tương giữa đối tượng) Communication protocols Sequence of method calls in a program … 3 4 1
- 2/28/2019 Sequence Diagram Interaction Partners Two-dimensional diagram Interaction partners are depicted as lifelines Horizontal axis: involved interaction partners Head of the lifeline Vertical axis: chronological order (thứ tự thời gian) of the interaction Rectangle that contains the expression roleName:Class Interaction = sequence of event specifications Roles are a more general concept than objects Object can take on different roles over its lifetime Body of the lifeline Vertical, usually dashed line Represents the lifetime of the object associated with it Head of the lifeline Body of the Lifeline 5 6 Exchanging Messages (1/2) Exchanging Messages (2/2) Order of messages: Interaction: sequence of events … on one lifeline … on different lifelines Message is defined via send event and receive event Execution specification Continuous bar »Happens before« Used to visualize when an interaction partner executes some behavior … on different lifelines which exchange messages Send event Receive event Execution specification 7 8 2
- 2/28/2019 Messages (1/3) Messages (2/3) Synchronous message (thông điệp đồng bộ) Object creation (tạo obj) Sender waits until it has received a response message Dashed arrow before continuing Syntax of message name: msg(par1,par2) Arrowhead points to the head of the lifeline of the msg: the name of the message object to be created par: parameters separated by commas Keyword new Asynchronous message (thông điệp bất đồng bộ) Sender continues without waiting for a response message Object destruction (hủy obj) Syntax of message name: msg(par1,par2) Object is deleted Response message (thông điệp phản hồi) Large cross (×) at the end of the lifeline May be omitted if content and location are obvious Syntax: att=msg(par1,par2):val att: the return value can optionally be assigned to a variable msg: the name of the message par: parameters separated by commas val: return value 9 10 Messages (3/3) Combined Fragments Found message (thông điệp từ vô danh) Model various control structures Sender of a message is unknown or not relevant 12 predefined types of operators Lost message (thông điệp bị mất) Combined Fragment Receiver of a message is unknown or not relevant Time-consuming message (thông điệp tốn thời gian) "Message with duration" Operator Usually messages are assumed to be transmitted Operand without any loss of time Express that time elapses between the sending and the receipt of a message Operand Operand 11 12 3
- 2/28/2019 Types of Combined Fragments alt Fragment Operator Purpose To model alternative Branches and alt Alternative interaction (tương tác có thể lựa chọn) sequences loops opt Optional interaction (tương tác tùy chọn) Similar to switch statement in loop Repeated interaction (tương tác lặp) Java break Exception interaction (tương tác ngoại lệ) Guards are used to select the seq Weak order (lệnh yếu) one path to be executed Concurrency and order strict Strict order (lệnh mạnh) Guards par Concurrent interaction (tương tác song song) Modeled in square brackets critical Atomic interaction (tương tác đơn nguyên) default: true predefined: [else] ignore Irrelevant interaction (tương tác không phù hợp) Filters and assertions consider Relevant interaction (tương tác phù hợp) Multiple operands assert Asserted interaction (tương tác chèn) Guards have to be disjoint to neg Invalid interaction (tương tác không hợp lệ) avoid indeterministic behavior 13 14 opt Fragment loop Fragment To model an optional To express that a sequence is to be executed repeatedly sequence Exactly one operand Actual execution at runtime Keyword loop followed by the minimal/maximal number of iterations is dependent on the guard (min..max) or (min,max) Exactly one operand default: (*) .. no upper limit Similar to if statement Guard without else branch Evaluated as soon as the minimum number of iterations has taken place equivalent to alt fragment Checked for each iteration within the (min,max) limits with two operands, one of If the guard evaluates to false, the execution of the loop is terminated which is empty Max Min Guard Notation alternatives: loop is loop(3,8) = loop(3..8) executed at loop(8,8) = loop (8) least once, then loop = loop (*) = loop(0,*) as long as a
- 2/28/2019 break Fragment loop and break Fragment - Example Simple form of exception handling Exactly one operand with a guard If the guard is true: Interactions within this operand are executed Remaining operations of the surrounding fragment are omitted Interaction continues in the next higher level fragment Different behavior than opt fragment Not executed if break is executed 17 18 seq Fragment seq Fragment – Example Default order of events Weak sequencing: 1. The ordering of events within each of the operands is maintained in the result. 2. Events on different lifelines from different operands may come in any order. 3. Events on the same lifeline from different operands are ordered such that an event of the first operand comes before that of the second operand. 19 20 5
- 2/28/2019 strict Fragment strict Fragment - Example Sequential interaction with order Order of event occurrences on different lifelines between different operands is significant Messages in an operand that is higher up on the vertical axis are always exchanged before the messages in an operand that is lower down on the vertical axis 21 22 par Fragment par Fragment - Example To set aside chronological order between messages in different operands Execution paths of different operands can be interleaved Restrictions of each operand need to be respected Order of the different operands is irrelevant Concurrency, no true parallelism 23 24 6
- 2/28/2019 Coregion Coregion – Example To model concurrent events of a single lifeline Order of event occurrences within a coregion is not restricted Area of the lifeline to be covered by the coregion is marked by square brackets rotated by 90 degrees Impact of coregion Coregion 25 26 critical Fragment critical Fragment - Example Atomic area in the interaction (one operand) To make sure that certain parts of an interaction are not interrupted by unexpected events Order within critical: default order seq 27 28 7
- 2/28/2019 ignore Fragment consider Fragment To indicate irrelevant messages To specify those messages that are of particular importance for the Messages may occur at runtime but have no further significance interaction under consideration Exactly one operand Exactly one operand, dual to ignore fragment Irrelevant messages in curly brackets after the keyword ignore Considered messages in curly brackets after the keyword consider 29 30 ignore vs. consider assert Fragment To identify certain modeled traces as mandatory Deviations that occur in reality but that are not included in the diagram are not permitted Exactly one operand 31 32 8
- 2/28/2019 neg Fragment Interaction Reference To model invalid interactions Integrates one sequence diagram in another sequence diagram Describing situations that must not occur Exactly one operand Purpose Explicitly highlighting frequently occurring errors Depicting relevant, incorrect sequences 33 34 Gate Continuation Marker Allows you to send and receive messages beyond the boundaries of Modularizes the operands of an alt fragment the interaction fragment Breaks down complex interactions into parts and connect them to one another with markers Start marker points to target marker No return to the start marker (in contrast to an interaction reference) Target marker Start marker 35 36 9
- 2/28/2019 Local Attributes and Parameters Time Constraints Every sequence diagram is enclosed by a rectangular frame with a Types small pentagon in the upper left corner Point in time for event Keyword sd, name of the sequence diagram, parameters (optional) occurrence Relative: e.g., after(5sec) Example: void func (int par1, int par2) { Absolute: e.g., at(12.00) int x = 0; Time period between two events String y = "Test"; {lower..upper} ... E.g., {12.00..13.00} } Predefined actions now: current time Option 1: Parameter Option 2: Can be assigned to an attribute and then used in a time constraint Duration: calculation of the Local duration of a message attributes transmission 37 38 State Invariant Four Types of Interaction Diagrams (1/4) Asserts that a certain condition must be fulfilled at a certain time Based on the same concepts Always assigned to a specific lifeline Generally equivalent for simple interactions, but different focus Evaluation before the subsequent event occurs If the state invariant is not true, either the model or the implementation Sequence diagram is incorrect Vertical axis: Three alternative notations: chronological order Horizontal axis: interaction partners 39 40 10
- 2/28/2019 Four Types of Interaction Diagrams (2/4) Four Types of Interaction Diagrams (3/4) Communication diagram Timing diagram Models the relationships between communication partners Shows state changes of the interaction partners that result from the Focus: Who communicates with whom occurrence of events Time is not a separate dimension Vertical axis: interaction partners Message order via decimal classification Horizontal axis: chronological order 41 42 Four Types of Interaction Diagrams (4/4) Notation Elements (1/2) Interaction overview diagram Name Notation Description Visualizes order of different interactions Allows to place various interaction diagrams in a logical order Interaction partners involved in Lifeline the communication Basic notation concepts of activity diagram Destruction Time at which an interaction partner event ceases to exist Combined Control constructs fragment 43 44 11
- 2/28/2019 Notation Elements (2/2) Name Notation Description Synchronous Sender waits for a response message message Response Response to a synchronous message message Sender continues its own work Asynchronous after sending the asynchronous communication message Lost message Message to an unknown receiver Message from an unknown Found message sender 45 46 12
CÓ THỂ BẠN MUỐN DOWNLOAD
-
Bài giảng Phân tích thiết kế hệ thống mạng - ThS. Lê Xuân Thành
52 p | 725 | 95
-
Bài giảng Phân tích thiết kế hệ thống: Bài giảng 5 - TS. Đào Nam Anh
87 p | 193 | 31
-
Bài giảng Phân tích thiết kế hệ thống: Bài giảng 3 - TS. Đào Nam Anh
60 p | 131 | 21
-
Bài giảng Phân tích thiết kế hệ thống: Bài giảng 6 - TS. Đào Nam Anh
22 p | 129 | 16
-
Bài giảng Phân tích thiết kế hệ thống: Bài giảng 1 - TS. Đào Nam Anh
78 p | 142 | 16
-
Bài giảng Phân tích thiết kế hệ thống: Bài giảng 2 - TS. Đào Nam Anh
28 p | 138 | 15
-
Bài giảng Phân tích thiết kế hệ thống: Bài giảng 4 - TS. Đào Nam Anh
12 p | 156 | 15
-
Bài giảng Phân tích thiết kế hệ thống: Bài giảng 7 - TS. Đào Nam Anh
39 p | 111 | 13
-
Bài giảng Phân tích thiết kế hướng đối tượng - ThS. Lê Trung Hiếu
85 p | 91 | 9
-
Bài giảng Phân tích thiết kế hướng đối tượng: Chương 5 - Lê Thị Minh Nguyện
11 p | 101 | 8
-
Bài giảng Phân tích thiết kế giải thuật: Chương 1 - Trịnh Huy Hoàng
72 p | 120 | 8
-
Bài giảng Phân tích thiết kế hệ thống thông tin: Bài 11 - TS. Trần Mạnh Tuấn
29 p | 55 | 7
-
Bài giảng Phân tích thiết kế giải thuật: Chương 4 - Trịnh Huy Hoàng
90 p | 108 | 7
-
Bài giảng Phân tích thiết kế giải thuật - Chương 37: Giải thuật xấp xỉ
21 p | 111 | 7
-
Bài giảng Phân tích thiết kế hệ thống thông tin: Bài 9 - TS. Trần Mạnh Tuấn
46 p | 62 | 6
-
Bài giảng Phân tích thiết kế hướng đối tượng: Chương 4 - Lê Thị Minh Nguyện
14 p | 90 | 5
-
Bài giảng Phân tích thiết kế và giải thuật - Chương 1: Kỹ thuật phân tích giải thuật
59 p | 22 | 3
-
Bài giảng Phân tích thiết kế và giải thuật - Chương 2: Kỹ thuật thiết kế giải thuật
80 p | 57 | 2
Chịu trách nhiệm nội dung:
Nguyễn Công Hà - Giám đốc Công ty TNHH TÀI LIỆU TRỰC TUYẾN VI NA
LIÊN HỆ
Địa chỉ: P402, 54A Nơ Trang Long, Phường 14, Q.Bình Thạnh, TP.HCM
Hotline: 093 303 0098
Email: support@tailieu.vn