OBJECT-ORIENTED ANALYSIS OBJECT-ORIENTED ANALYSIS AND DESIGN WITH UML 2.0 AND DESIGN WITH UML 2.0 Bé m«n C«ng nghÖ phÇn mÒm Bé m«n C«ng nghÖ phÇn mÒm KHOA CÔNG NGHỆ THÔNG TIN KHOA CÔNG NGHỆ THÔNG TIN TRƯỜNG ĐẠI HỌC BÁCH KHOA HÀ NỘI TRƯỜNG ĐẠI HỌC BÁCH KHOA HÀ NỘI !"#$% !& !"#$% !& '()"$!& '()"$!& *"+,,! !& *"+,,! !& - - . /"+%0$& . /"+%0$& 1 1 2 . "3$$$4& 2 . "3$$$4& 5 5 678 "9$$% : !& 678 "9$$% : !& - - ;<=>%!0?@'( ;<=>%!0?@'( !A !A ! ! BC ,,+ B$%D!%EF$,!,04"&B%$, BC ,, C ,, + $%D!%EF$,!,04"&B%$, 1 1 *GEH ! *GEH ! =!% * !/I =!% * !/I H7H H7H JK28A L'I"M& JK28A L'I"M& N7O N7O OPA ! OPA ! operationName([direction]parameter : class, ) : returnType operationName([direction]parameter : class, ) : returnType 3%$!B 3%$!B in in "EQ&R "EQ&R out out !Q !Q inout inout S' % EHTMR0 !@EPU A NH S' % EHTMR0 !@EPU A NH E,L E,L 5 5 V'WOP ! V'WOP ! XOPA !RY<$E<Z> XOPA !RY<$E<Z> E,L8B E,L8B S'I%4[$! E% 4 E0 S'I%4[$! E% 4 E0 C80 460\ ! 4 C80 460\ ! 4 C8]4M C8]4M ^%EQ ^%EQ C!H E,LI> C!H E,LI> C/ E,LRL C/ E,LRL %4[L'I 4G!=O %4[L'I 4G!=O > > _ _ Public operation s Protected operations Private operations `=EG%4^A ! `=EG%4^A ! "#$% !a,04& "#$% !a,04& `=EG%4^'I,K2?b> `=EG%4^'I,K2?b> Hc88 Hc88 C8?0R%!$$R!Q%G $ C8?0R%!$$R!Q%G $ `=EG%4^'I0?d `=EG%4^'I0?d '!e '!e CP>, 'I,K2B CP>, 'I,K2B f f `0 $,, `0 $,, g g `%!$$ $,, `%!$$ $,, h h `%G $ $,, `%G $ $,, C ,, - %G $+%0$ f0+%0$ g%!$$+%0$ h%G $#$% !"& f0#`$% !"& g%!$$#$% !"& i i `=EG"J!$& `=EG"J!$& ,L'I?>A /j ! ,L'I?>A /j ! B B k, $B?>!El?>A El k, $B?>!El?>A El C ,,D$%B?>!NH?>A C ,,D$%B?>!NH?>A `=EGC ,,D$%'IP>0m= `=EGC ,,D$%'IP>0m= '*/j ! '*/j ! C ,, h ,,D$%J!$+% h, $J!$+% f ,,D$%J!$#"& f, $J!$#"& n n a/2BJ!$ a/2BJ!$ J$ h E$ h %$,, h$<+G k3B f J$$"op$J$$BJ$$RopD!%J$E$,$%BJ$E$,$%& f$J$$"opD!%J$E$,$%BJ$E$,$%&BJ$$ f ,`%$%$7,$,"opD!%C!%,$#DD$%BC!%,$#DD$%&B0!!$ g ,,$"op$C!%,$#DD$%BC!%,$#DD$%&B0!!$ f$$<+G k3"&B h,$k3 [...]... () + // mark as enrolled in () + // mark as committed () 25 Thiết kế bội số quan hệ Multiplicity = 1, hoặc Multiplicity = 0 1 Có thể được thực hiện trực tiếp bằng một giá trị đơn hoặc con trỏ Không cần thiết kế thêm LecturerInfo 0 1 0 1 CourseInfo + Instructor Multiplicity > 1 Không thể sử dụng giá trị đơn hoặc con trỏ Cần thiết kế thêm nữa Cần một cho CourseInfo LecturerInfo 0 1 0 * CourseInfo... Schedule[] 28 Chương 5 Thiết kế lớp 1 2 3 4 5 6 Xác định các thao tác (Operation) Xác định phương thức (Method) Xác định các liên kết (Association) Xác định các thuôôc tính (Attribute) Xác định phụ thuôôc (Dependency) Xác định tổng quát hóa (Generalization) 29 4 Xác định các thuô c tính ô Xem xét các mô tả phương thức Xem xét các trạng thái Xem xét bất kỳ thông tin nào mà lớp đó... (Navigability) là gì? Điều hướng từ một lớp kết hợp đến lớp đích sử dụng association CourseRegistrationController CourseInfo 22 Navigability: Hướng nào thực sự cần? Xem xét các biểu đồ tương tác Thậm chí khi cả hai hướng đều có vẻ cần nhưng một hướng lại vẫn hoạt động tốt Navigability theo 1 hướng ít xảy ra Số lượng thể hiện của một lớp là nhỏ Schedule + primaryCourses 0 *... tham số sẽ được thực thi và sử dụng Các mối quan hêô sẽ được thực thi và sử dụng 14 Nội dung 1 2 3 4 5 6 Xác định các thao tác (Operation) Xác định phương thức (Method) Xác định các liên kết (Association) Xác định các thuôôc tính (Attribute) Xác định phụ thuôôc (Dependency) Xác định tổng quát hóa (Generalization) 15 3 Xác định các liên kết Mục đích Tinh chỉnh các kết... is non-shared aggregation 18 Aggregation hay Composition? Xem xét vòng đời của Class1 và Class2 Class1 Class2 Aggregation Class1 Class2 Composition 19 Ví dụ: Composition CourseInfo 1 Schedule 0 * CourseRegistrationForm 1 CourseRegistrationController 1 20 Attributes và Composition Sử dụng composition khi: Các đặc tính (property) cần định danh độc lập Nhiều lớp có cùng các đặc tính... Client Supplier Mục đích Xác định khi các mối quan hệ cấu trúc (association hoặc aggregation) không cần đến Cần xem xét: Cái gì làm cho supplier có thể được nhìn thấy client? 36 Liên kết và Phụ thuộc Kết hợp là mối quan hệ cấu trúc Phụ thuộc là mối quan hệ phicấu trúc Để các đối tượng có thể “biết lẫn nhau”, chúng phải được nhìn thấy Local variable reference Parameter reference... = Default Tuân theo quy ước đặt tên của ngôn ngữ cài đặt và của dự án Kiểu (type) nên là kiểu dữ liệu cơ bản trong ngôn ngữ thực thi Kiểu dữ liệu có sẵn, kiểu dữ liệu người dùng định nghĩa, hoặc lớp tự định nghĩa Xác định phạm vi truy cập Public: + Private: Protected: # 31 Các thuộc tính dẫn xuất (derived) Thuộc tính dẫn xuất là gì? Là thuộc tính có giá trị có thể được tính... historyNo: int result: int subjectID: String subjectName: String numberOfCredit: int 0 4 34 Nội dung 1 2 3 4 5 6 Xác định các thao tác (Operation) Xác định phương thức (Method) Xác định các liên kết (Association) Xác định các thuôôc tính (Attribute) Xác định phụ thuôôc (Dependency) Xác định tổng quát hóa (Generalization) 35 5 Xác định phụ thuô ôc (Dependency) Một phụ thuộc là gì?...12 Nội dung 1 2 3 4 5 6 Xác định các thao tác (Operation) Xác định phương thức (Method) Xác định các liên kết (Association) Xác định các thuôôc tính (Attribute) Xác định phụ thuôôc (Dependency) Xác định tổng quát hóa (Generalization) 13 2 Xác định phương thức Phương thức (method) là gì? Mô . !a,04& `=EG%4^'I,K2?b> `=EG%4^'I,K2?b> Hc 8 8 Hc 8 8 C8?0R%!$$R!Q%G $ C8?0R%!$$R!Q%G $ `=EG%4^'I0?d `=EG%4^'I0?d '!e '!e CP>,. E,L8B E,L8B S'I%4[$! E% 4 E0 S'I%4[$! E% 4 E0 C80 460 ! 4 C80 460 ! 4 C8]4M C8]4M ^%EQ ^%EQ C!H. ^ CQ/"%!$%4&Y ^ [ 8 ]Q/ [ 8 ]Q/ CQ/ 8 EN%z)=GQ CQ/ 8 EN%z)=GQ /A