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 |
Chia sẻ: phuongt97 | Lượt xem: 612 | 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