Mục tiêu
w Tìm hiểu mục đích của bước thiết kế Class và
vị trí của công đoạn này trong qui trình
w Xác định bổ sung các class và quan hệ của
chúng cần để hỗ trợ cho việc cài đặt các cơ
chế kiến trúc đã chọn
w Xác định và phân tích việc chuyển đổi trạng
thái các đối tường trong các class kiểm soát
được trạng thái
w Tinh chỉnh các quan hệ, operation, và thuộc
tính
 
              
                                            
                                
            
 
            
                 131 trang
131 trang | 
Chia sẻ: phuongt97 | Lượt xem: 788 | Lượt tải: 0 
              
            Bạn đang xem trước 20 trang nội dung tài liệu Phân tích và Thiết kế Hướng đối tượng dùng UML -  Module 13: Thiết kế Class - Dương Anh Đức, để xem tài liệu hoàn chỉnh bạn click vào nút DOWNLOAD ở trên
hay nhieàu class ancestor
 Account
 w Laø quan heä “Laø moät daïng cuûa” balance
 name
 w Trong phaân tích, ít khi duøng ñeán number
 Superclass 
 Withdraw()
 (parent) CreateStatement()
 Generalization 
 Relationship
 Checking Savings
 Subclasses
 GetInterest()
 descendents
PT & TK Höôùng ñoái töôïng – Thieát keá kieán truùc
Döông Anh Ñöùc 92
Abstract vaø Concrete Class
 w Abstract class khoâng coù baát kyø theå hieän naøo
 w Concrete classes coù theå coù theå hieän (object)
 Animal
 Abstract class
Chuyeân bieät hoùa {abstract}
 talk () {abstract} Abstract operation
 Communication Khoâng coù theå hieän cuûa Animal
 Lion Tiger
 talk () talk ()
 Taát caû caùc object ñeàu hoaëc laø Lion hoaëc laø Tiger
PT & TK Höôùng ñoái töôïng – Thieát keá kieán truùc
Döông Anh Ñöùc 93
Nhaéc laïi: Ña keá thöøa
 w Moät class coù theå keá thöøa töø nhieàu class
 FlyingThing Animal
 multiple
 inheritance
 Airplane Helicopter Bird Wolf Horse
 Duøng ña keá thöùc chæ khi thaät caàn thieát, vaø phaûi luoân caån thaän !
PT & TK Höôùng ñoái töôïng – Thieát keá kieán truùc
Döông Anh Ñöùc 94
Caùc vaán ñeà cuûa ña keá thöøa
 Teân cuûa attribute hay Laëp laïi vieäc keá thöøa
 operation bò truøng
 FlyingThing Animal AnimateObject
 color color color
 getColor getColor 
 FlyingThing Animal
 Bird
 Bird
 Lôøi giaûi cuûa caùc vaán ñeà treân phuï thuoäc caøi ñaët cuï theå
PT & TK Höôùng ñoái töôïng – Thieát keá kieán truùc
Döông Anh Ñöùc 95
Caùc raøng buoäc cuûa quan heä toång quaùt hoùa
 w Complete (Hoaøn chænh)
 § Keát thuùc toaøn boä caây keá thöøa trong thieát keá
 w Incomplete (Khoâng hoaøn chænh )
 § Caây keá thöøa coù theå môû roäng
 w Disjoint (Phaân taùch)
 § Caùc Subclass loaïi tröø laàn nhau
 § Khoâng hoã trôï ña keá thöøa
 w Overlapping (Choàng laép)
 § Caùc Subclass khoâng loaïi tröø laãn nhau
 § Hoã trôï ña keá thöøa
PT & TK Höôùng ñoái töôïng – Thieát keá kieán truùc
Döông Anh Ñöùc 96
Ví duï: Generalization Constraints
 Khoâng hoã trôï 
 Asset
 ña keá thöøa
 {disjoint}
 Real
 Bank Security
 Account Estate
 {disjoint,complete}
 {disjoint}
 Saving Checking Stock Bond
 Keát thuùc caây keá thöøa
PT & TK Höôùng ñoái töôïng – Thieát keá kieán truùc
Döông Anh Ñöùc 97
Ví duï: Generalization Constraints (tt.)
 Hoã trôï 
 ña keá thöøa
 Vehicle
 {overlapping}
 Land Water
 Vehicle Vehicle
 Amphibious
 Vehicle
PT & TK Höôùng ñoái töôïng – Thieát keá kieán truùc
Döông Anh Ñöùc 98
Choïn Generalization hay Aggregation
 w Raát deã nhaàm laãm giöõa Generalization vaø
 aggregation
 § Generalization bieåu dieãn quan heä “laø moät” hay
 “daïng cuûa”
 § Aggregation bieåu dieãn quan heä “moät boä phaän cuûa”
 Window Scrollbar
 Coù ñuùng khoâng?
 WindowWithScrollbar
PT & TK Höôùng ñoái töôïng – Thieát keá kieán truùc
Döông Anh Ñöùc 99
Choïn Generalization hay Aggregation
 Window Scrollbar
 WindowWithScrollbar
 Moät WindowWithScrollbar “laø moät” Window
 Window
 Moät WindowWithScrollbar “chöùa moät” Scrollbar
 WindowWithScrollbar Scrollbar
 1 1
PT & TK Höôùng ñoái töôïng – Thieát keá kieán truùc
Döông Anh Ñöùc 100
Söû duïng quan heä toång quaùt hoùa
 w Chia seû caùc thuoäc tính vaø haønh vi chung
 w Chia seû caøi ñaët
 w Caøi ñaët cô cheá Polymorphism
 w Caøi ñaët cô cheá Metamorphosis
PT & TK Höôùng ñoái töôïng – Thieát keá kieán truùc
Döông Anh Ñöùc 101
Söû duïng quan heä toång quaùt hoùa
 w Chia seû caùc thuoäc tính vaø haønh vi chung
 w Chia seû caøi ñaët
 w Caøi ñaët cô cheá Polymorphism
 w Caøi ñaët cô cheá Metamorphosis
PT & TK Höôùng ñoái töôïng – Thieát keá kieán truùc
Döông Anh Ñöùc 102
Chia seû caùc thuoäc tính vaø haønh vi chung
 w Tuaân thuû qui taéc laäp trình “Laø moät daïng cuûa”
 w Khaû naêng thay theå Class List
 Animal insertTop (Item)
 insertBottom (Item)
 removeTop ()
 talk () removeBottom ()
 insert (Item, 
 position)
 Lion Tiger
 talk () talk ()
 Stack
 Caùc class treân coù tuaân thuû IS-A style of programming?
PT & TK Höôùng ñoái töôïng – Thieát keá kieán truùc
Döông Anh Ñöùc 103
Chia seû caùc thuoäc tính vaø haønh vi chung (tt)
 List
 Animal
 insertTop (Item)
 insertBottom (Item)
 talk () removeTop ()
 removeBottom ()
 insert (Item, 
 position)
 Lion Tiger
 talk () talk ()
 Stack
PT & TK Höôùng ñoái töôïng – Thieát keá kieán truùc
Döông Anh Ñöùc 104
Söû duïng quan heä toång quaùt hoùa
 w Chia seû caùc thuoäc tính vaø haønh vi chung
 w Chia seû caøi ñaët
 w Caøi ñaët cô cheá Polymorphism
 w Caøi ñaët cô cheá Metamorphosis
PT & TK Höôùng ñoái töôïng – Thieát keá kieán truùc
Döông Anh Ñöùc 105
Chia seû caøi ñaët: Factoring (phaân chia)
 w Hoã trôï khaû naêng duøng laïi khi caøi ñaët class khaùc
 w Khoâng theå duøng neáu class baïn muoán “duøng 
 laïi” khoâng theå thay ñoåi
 List
 SequentialContainer
 insertTop (Item)
 insertBottom (Item) insertTop (Item)
 removeTop () removeTop ()
 removeBottom ()
 insert (Item, position)
 List
 Stack
 insertBottom (Item)
 removeBottom ()
 insert (Item, position)
 Stack
PT & TK Höôùng ñoái töôïng – Thieát keá kieán truùc
Döông Anh Ñöùc 106
Chia seû caøi ñaët: Delegation (ñaïi dieän)
 w Hoå trôï khaû naêng duøng laïi khi caøi ñaët class khaùc
 w Khoâng theå duøng neáu class baïn muoán “duøng 
 laïi” khoâng theå thay ñoåi
 List
 insertTop (Item)
 insertBottom (Item) List
 removeTop ()
 removeBottom () Stack insertBottom 
 insert (Item, position) (Item)
 push (Item) removeBottom ()
 pop (): Item 1 1 insert (Item, position)
 remove (position)
 Stack
PT & TK Höôùng ñoái töôïng – Thieát keá kieán truùc
Döông Anh Ñöùc 107
Quan heä keá thöøa daïng >
 w Caùc public operation, attribute vaø relationship 
 cuûa toå tieân khoâng nhìn thaáy ñöôïc bôûi caùc client 
 cuûa caùc theå hieän cuûa caùc class con chaùu
 w Caùc class con chaùu phaûi ñònh nghóa caùc truy 
 caäp ñeán operations, attributes, vaø relationships 
 cuûa toå tieân
 List
 push() and pop() coù theå truy caäp 
 insertBottom (Item)
 ñeán caùc method cuûa List nhöng caùc removeBottom ()
 insert (Item, 
 theå hieän cuûa Stack thì khoâng position)
 remove (position)
 insertTop (Item)
 >
 Stack
PT & TK Höôùng ñoái töôïng – Thieát keá kieán truùc push (Item)
Döông Anh Ñöùc 108 pop ()
Söû duïng quan heä toång quaùt hoùa
 w Chia seû caùc thuoäc tính vaø haønh vi chung
 w Chia seû caøi ñaët
 w Caøi ñaët cô cheá Polymorphism
 w Caøi ñaët cô cheá Metamorphosis
PT & TK Höôùng ñoái töôïng – Thieát keá kieán truùc
Döông Anh Ñöùc 109
Nhaéc laïi: Polymorphism laø gì ?
 w Khaû naêng che daáu nhieàu caøi ñaët beân döôùi moät
 interface duy nhaát
 Manufacturer B
 Manufacturer A Manufacturer C
 OO Principle:
 Encapsulation
PT & TK Höôùng ñoái töôïng – Thieát keá kieán truùc
Döông Anh Ñöùc 110
Caøi ñaët Polymorphism
 Animal
 talk ()
 Lion Tiger
 talk () talk ()
 Khoâng coù Polymorphism Coù Polymorphism
 if animal = “Lion” then
 do the Lion talk do the Animal talk
 else if animal = “Tiger” then
 do the Tiger talk
 end
PT & TK Höôùng ñoái töôïng – Thieát keá kieán truùc
Döông Anh Ñöùc 111
So saùnh Interface vaø Generalization
 w Caùc Interface hoã trôï bieåu dieãn ñoäc laäp vôùi caøi ñaët cuûa
 polymorphism
 § Realization relationships coù theå baêng ngang qua 
 caáu truùc phaân caáp cuûa quan heä toång quaùt hoùa
 w Caùc Interface chæ thuaàn laø ñaëc taû, khoâng coù haønh vi
 § Abstract base class coù theå ñònh nghóa attributes vaø
 associations
 w Caùc Interface hoaøn toaøn ñoäc laäp vôùi quan heä keá thöøa
 § Generalization thöôøng duøng ñeå caøi ñaët vieäc duøng 
 laïi
 § Interfaces thöôøng duøng ñeå ñaëc taû vieäc taùi söû duïng 
 caùc haønh vi
 w Generalization cung caáp moät caùch caøi ñaët 
 polymorphism
PT & TK Höôùng ñoái töôïng – Thieát keá kieán truùc
Döông Anh Ñöùc 112
Duøng QH toång quaùt hoùa ñeå caøi Polymorphism
 w Chæ cung caáp interface cho caùc class con chaùu?
 § Thieát keá toå tieân nhö moät abstract class
 § Moïi method caøi ñaët ôû caùc class con chaùu
 w Cung caáp interface vaø behavior maëc ñònh cho caùc
 class con chaùu?
 § Thieát keá toå tieân nhö moät concrete class vôùi caùc
 method maëc ñònh
 § Cho pheùp duøng caùc polymorphic operation
 w Cung caáp interface vaø behavior baét buoäc cho caùc
 class con chaùu?
 § Thieát keá toå tieân laø concrete class
 § Khoâng cho pheùp caùc polymorphic operation
PT & TK Höôùng ñoái töôïng – Thieát keá kieán truùc
Döông Anh Ñöùc 113
Söû duïng quan heä toång quaùt hoùa
 w Chia seû caùc thuoäc tính vaø haønh vi chung
 w Chia seû caøi ñaët
 w Caøi ñaët cô cheá Polymorphism
 w Caøi ñaët cô cheá Metamorphosis
PT & TK Höôùng ñoái töôïng – Thieát keá kieán truùc
Döông Anh Ñöùc 114
Metamorphosis laø gì?
 w Metamorphosis
 § 1. Moät thay ñoåi trong hình daïng, caáu truùc, hay 
 chöùc naêng; ñaëc bieät laø caùc thay ñoåi vaät lyù maø caùc 
 ñoäng vaät phaûi traûi qua, nhö con noøng noïc bieán 
 thaønh con eác
 § 2. Moïi thay ñoåi ñöôïc ghi nhaän, nhö trong caùc kyù 
 töï, theå hieän, hoaëc ñieàu kieän
 § Xem theâm Webster’s New World Dictionary, 
 Simon & Schuster, Inc., 1979
 Metamorphosis toàn taïi trong theå giôùi thöïc
 Laøm sao moâ hình hoùa chuùng?
PT & TK Höôùng ñoái töôïng – Thieát keá kieán truùc
Döông Anh Ñöùc 115
Ví duï: Metamorphosis
 w Trong tröôøng ñaïi hoïc, coù full time students vaø
 part time students
 § Full time students coù ngaøy toát nghieäp döï kieán coøn
 part time students laïi khoâng
 § Part time students coù theå ñaêng kyù hoïc toái ña 3 moân
 trong khi full time students khoâng bò giôùi haïn
 ParttimeStudent FulltimeStudent
 name name
 address address
 studentID studentID
 maxNumCourses gradDate
PT & TK Höôùng ñoái töôïng – Thieát keá kieán truùc
Döông Anh Ñöùc 116
Moät höôùng tieáp caän Modeling Metamorphosis
 w Coù theå taïo moät quan heä toång quaùt hoùa
 Chuyeän gì xaûy ra neáu 
 Student
 name moät part-time student 
 address trôû thaønh full-time 
 studentID
 student?
 ParttimeStudent FulltimeStudent
 maxNumCourses gradDate
PT & TK Höôùng ñoái töôïng – Thieát keá kieán truùc
Döông Anh Ñöùc 117
Moät höôùng tieáp caän khaùc
 w Quan heä keá thöøa coù theå duøng ñeå moâ hình hoùa 
 caáu truùc, haønh vi vaø quan heä chung vaø taïo quan 
 heä vôùi phaàn “thay ñoåi”
 Student
 Student
 name 1 1 Classification
 name address
 address studentID
 studentID
 ParttimeStudent FulltimeStudent FulltimeClassification ParttimeClassification
 maxNumCourses gradDate gradDate maxNumCourses
PT & TK Höôùng ñoái töôïng – Thieát keá kieán truùc
Döông Anh Ñöùc 118
Moät höôùng tieáp caän khaùc (tt)
 w Metamorphosis ñöôïc hoaøn taát bôûi object “noùi 
 chuyeän vôùi” phaàn “thay ñoåi”
 : Student : Student : Parttime : Fulltime
 Manager Classification Classification
 change to full time
 delete
 create
PT & TK Höôùng ñoái töôïng – Thieát keá kieán truùc
Döông Anh Ñöùc 119
Metamorphosis vaø tính meàm deûo
 w Kyõ thuaät naøy theâm tính meàm deûo cho moâ hình
 ResidentInformation Student
 dorm 1 1
 room name Classification
 roomKeyID 0..1 1 address
 studentID
 FulltimeClassification ParttimeClassification
 gradDate maxNumCourses
PT & TK Höôùng ñoái töôïng – Thieát keá kieán truùc
Döông Anh Ñöùc 120
Baøi taäp: Ñònh nghóa Generalizations
 w Haõy cho bieát:
 § Taát caû caùc design class
 w Haõy xaùc ñònh:
 § Taât caû caùc tinh chænh lieân quan ñeân generalizations 
 coù saün
 § Moïi öùng duïng generalization môùi
 • Kieåm tra laø ñaõ xem xeùtmoïi metamorphosis
 w Xaây döïng caùc löôïc ñoà:
 § Class diagram chöùa moïi quan heä toång quaùt hoùa 
 môùi (hay ñaõ tính chænh) giöõa caùc class
 § Tinh chænh use-case realizations (optional) 
PT & TK Höôùng ñoái töôïng – Thieát keá kieán truùc
Döông Anh Ñöùc 121
Caùc böôùc thieát keá Class
 w Taïo caùc Design Class ban ñaàu
 w Xaùc ñònh caùc Persistent Class
 w Ñònh nghóa caùc Operation
 w Ñònh nghóa Class Visibility
 w Ñònh nghóa caùc Method
 w Ñònh nghóa caùc traïng thaùi
 w Ñònh nghóa caùc thuoäc tính
 w Ñònh nghóa caùc phuï thuoäc
 w Ñònh nghóa caùc moãi keát hôïp
 w Ñònh nghóa caùc quan heä toång quaùt hoùa
 w Giaûi quyeát ñuïng ñoä giöõa caùc Use-Case
 w Xöû lyù caùc yeâu caàu phi chöùc naêng noùi chung
 w Checkpoints
PT & TK Höôùng ñoái töôïng – Thieát keá kieán truùc
Döông Anh Ñöùc 122
Giaûi quyeát ñuïng ñoä giöõa caùc Use-Case
 w Nhieàu use case coù theå truy caäp rieâng reõ ñeán caùc 
 design object
 w Options
 § Duøng cô cheá truyeàn message ñoàng boä => ñeán 
 tröôùc ñöôïc xöû lyù tröôùc
 § Xaùc ñònh caùc operation (hay code) caàn protect
 § AÙp duïng cô cheá access control
 • Laäp haøng ñôïi Message
 • Semaphores (hoaëc 'tokens')
 • Caùc cô cheá khoùa khaùc
 w Lôøi giaûi phuï thuoäc nhieàu vaøo moâi tröôøng caøi ñaët
PT & TK Höôùng ñoái töôïng – Thieát keá kieán truùc
Döông Anh Ñöùc 123
Caùc böôùc thieát keá Class
 w Taïo caùc Design Class ban ñaàu
 w Xaùc ñònh caùc Persistent Class
 w Ñònh nghóa caùc Operation
 w Ñònh nghóa Class Visibility
 w Ñònh nghóa caùc Method
 w Ñònh nghóa caùc traïng thaùi
 w Ñònh nghóa caùc thuoäc tính
 w Ñònh nghóa caùc phuï thuoäc
 w Ñònh nghóa caùc moãi keát hôïp
 w Ñònh nghóa caùc quan heä toång quaùt hoùa
 w Giaûi quyeát ñuïng ñoä giöõa caùc Use-Case
 w Xöû lyù caùc yeâu caàu phi chöùc naêng noùi chung
 w Checkpoints
PT & TK Höôùng ñoái töôïng – Thieát keá kieán truùc
Döông Anh Ñöùc 124
Xöû lyù caùc yeâu caàu phi chöùc naêng noùi chung
 Analysis Class Analysis Mechanism(s)
 Student Persistency, Security
 Schedule Persistency, Security
 CourseOffering Persistency, Legacy Interface
 Course Persistency, Legacy Interface
 RegistrationController Distribution
 Analysis Design Implementation
 Mechanism Mechanism Mechanism
 (Conceptual) (Concrete) (Actual)
 Legac
 y Data Some Design 
 Persistency JDBC
 RDBMS Class
 New 
 Persistency Data ObjectStore Design
 OODBMS Guidelines
 Distribution Remote Method Java 1.2 from Sun
 Invocation (RMI)
 Analysis Design Implementation
PT & TK Höôùng ñoái töôïng – Thieát keá kieán truùc
Döông Anh Ñöùc 125
Caùc böôùc thieát keá Class
 w Taïo caùc Design Class ban ñaàu
 w Xaùc ñònh caùc Persistent Class
 w Ñònh nghóa caùc Operation
 w Ñònh nghóa Class Visibility
 w Ñònh nghóa caùc Method
 w Ñònh nghóa caùc traïng thaùi
 w Ñònh nghóa caùc thuoäc tính
 w Ñònh nghóa caùc phuï thuoäc
 w Ñònh nghóa caùc moãi keát hôïp
 w Ñònh nghóa caùc quan heä toång quaùt hoùa
 w Giaûi quyeát ñuïng ñoä giöõa caùc Use-Case
 w Xöû lyù caùc yeâu caàu phi chöùc naêng noùi chung
 w Checkpoints
PT & TK Höôùng ñoái töôïng – Thieát keá kieán truùc
Döông Anh Ñöùc 126
Checkpoints: Caùc Class
 w Teân cuûa moãi class coù phaûn aùnh roõ vai troø cuûa noù khoâng?
 w Class coù bieåu dieãn moät single well-defined abstraction? 
 w Taát caû caùc attribute vaø traùch nhieäm coù gaén keát vôùi nhau?
 w Coù baát kyø class attribute, operation hay relationship naøo caàn 
 toång quaùt hoùa, nghóa laø, chuyeån leân toå tieân khoâng?
 w Moïi yeâu caàu treân class ñaõ xöû lyù?
 w Moïi ñoøi hoûi treân class phuø hôp vôùi vôùi statecharts moâ hình hoùa
 haønh vi cuûa class vaø caùc theå hieän cuûa noù?
 w Ñaõ moâ taû troïn veïn chu kyø soáng cuûa caùc theå hieän cuûa class ?
 w Class thöïc hieän moïi haønh vi caàn thieát?
PT & TK Höôùng ñoái töôïng – Thieát keá kieán truùc
Döông Anh Ñöùc 127
Checkpoints: Operations
 w Caùc operation coù deã hieåu?
 w Caùc moâ taû traïng thaùi cuûa class vaø haønh vi cuûa caùc
 object cuûa noù coù chính xaùc?
 w Class coù thöïc hieän ñuùng haønh vi yeâu caàu noù?
 w Baïn ñaõ caùc ñònh caùc tham soá ñuùng chöa ?
 w Baïn ñaõ gaùn ñaày ñuû operations cho caùc message cuûa 
 moãi object ?
 w Caùc ñaëc taû caøi ñaët (neáu coù) cuûa operation coù chính 
 xaùc ?
 w Caùc operation signature coù phuø hôïp vôùi NNLT caøi ñaët 
 heä thoáng?
 w Taát caû caùc operation ñeà caàn cho use-case realization?
PT & TK Höôùng ñoái töôïng – Thieát keá kieán truùc
Döông Anh Ñöùc 128
Checkpoints: Attributes
 w Moãi attribute bieåu dieãn moät khaùi nieäm ñôn?
 w Teân cuûa caùc attribute coù gôïi nhôù?
 w Taát caû caùc attribute laø caàn thieát cho caùc use-
 case realization ?
PT & TK Höôùng ñoái töôïng – Thieát keá kieán truùc
Döông Anh Ñöùc 129
Checkpoints: Relationships
 w Teân cuûa role gôïi nhôù?
 w Baûn soá cuûa caùc relationship coù chính xaùc?
PT & TK Höôùng ñoái töôïng – Thieát keá kieán truùc
Döông Anh Ñöùc 130
Nhaéc laïi: Class Design
 w Muïc ñích cuûa Class Design laø gì?
 w Caùc class ñöôïc tinh chænh baèng caùch naøo?
 w Caùc statechart ñöôïc taïo cho moãi class?
 w Caùc component chính cuûa statechart laø gì ? Cho 
 moâ taû ngaén goïn veà moãi thöù.
 w Coù nhöõng daïng tinh chænh relationship naøo?
 w Söï khaùc nhau giöõa association vaø dependency?
 w Ta phaûi laøm gì vôùi operations vaø attributes?
PT & TK Höôùng ñoái töôïng – Thieát keá kieán truùc
Döông Anh Ñöùc 131
            Các file đính kèm theo tài liệu này:
 phan_tich_va_thiet_ke_huong_doi_tuong_dung_uml_module_13_thi.pdf phan_tich_va_thiet_ke_huong_doi_tuong_dung_uml_module_13_thi.pdf