Kỹ nghệ phần mềm - Bài 7: Thiết kế hướng đối tượng

Tài liệu Kỹ nghệ phần mềm - Bài 7: Thiết kế hướng đối tượng: Bộ môn Công nghệ phần mềm- Khoa CNTT- ĐHCN Email: vynv@coltech.vnu.vn Kỹ nghệ phần mềm Software Engeneering Nguyễn Văn Vỵ Bộ mụn Cụng nghệ phần mềm – ĐHCN 2 NguyễnVănVỵ Nội dung Bài 7: Thiết kế hướng đối tượng „ Vấn đề tồn tại trong h−ớng kiến trúc „ Khái niệm liên quan đến đối t−ợng „ Ngôn ngữ UML „ Phân tích h−ớng đối t−ợng „ Thiết kế h−ớng đối t−ợng „ Sử dụng mẫu thiết kế Bộ mụn Cụng nghệ phần mềm – ĐHCN 3 NguyễnVănVỵ TÀI LiỆU THAM KHẢO 1. Nguyễn Văn Vỵ, Nguyễn Việt Hà. Giỏo trỡnh kỹ nghệ phần mềm. Nhà xuất bản Đại học Quốc gia Hà nội, 2008 2. Grady Booch, James Rumbaugh, Ivar Jacobson. The Unified Modeling language User Guid. Addison-Wesley, 1998. 3. M. Ould. Managing Software Quality and Business Risk, John Wiley and Sons, 1999. 4. Roger S.Pressman, Software Engineering, a Practitioner’s Approach. Fifth Edition, McGraw Hill, 2001. 5. Ian Sommerville, Software Engineering. Sixth Edition, Addison- Wasley, 2001. 6. Nguyễn Văn Vỵ. Phõn tớch thiết kế hệ...

pdf54 trang | Chia sẻ: hunglv | Lượt xem: 1107 | Lượt tải: 0download
Bạn đang xem trước 20 trang mẫu tài liệu Kỹ nghệ phần mềm - Bài 7: Thiết kế hướng đối tượng, để tải tài liệu gốc về máy bạn click vào nút DOWNLOAD ở trên
Bé m«n C«ng nghÖ phÇn mÒm- Khoa CNTT- §HCN Email: vynv@coltech.vnu.vn Kỹ nghệ phần mềm Software Engeneering NguyÔn V¨n Vþ Bộ môn Công nghệ phần mềm – ĐHCN 2 NguyễnVănVỵ Nội dung Bài 7: Thiết kế hướng đối tượng „ VÊn ®Ò tån t¹i trong h−íng kiÕn tróc „ Kh¸i niÖm liªn quan ®Õn ®èi t−îng „ Ng«n ng÷ UML „ Ph©n tÝch h−íng ®èi t−îng „ ThiÕt kÕ h−íng ®èi t−îng „ Sö dông mÉu thiÕt kÕ Bộ môn Công nghệ phần mềm – ĐHCN 3 NguyễnVănVỵ TÀI LiỆU THAM KHẢO 1. Nguyễn Văn Vỵ, Nguyễn Việt Hà. Giáo trình kỹ nghệ phần mềm. Nhà xuất bản Đại học Quốc gia Hà nội, 2008 2. Grady Booch, James Rumbaugh, Ivar Jacobson. The Unified Modeling language User Guid. Addison-Wesley, 1998. 3. M. Ould. Managing Software Quality and Business Risk, John Wiley and Sons, 1999. 4. Roger S.Pressman, Software Engineering, a Practitioner’s Approach. Fifth Edition, McGraw Hill, 2001. 5. Ian Sommerville, Software Engineering. Sixth Edition, Addison- Wasley, 2001. 6. Nguyễn Văn Vỵ. Phân tích thiết kế hệ thống thông tin hiện đại. Hướng cấu trúc và hướng đối tượng, NXB Thống kê, 2002, Hà Nội. Bộ môn Công nghệ phần mềm – ĐHCN 4 NguyễnVănVỵ KiÕn tróc phÇn mÒm truyÒn thèng Bộ môn Công nghệ phần mềm – ĐHCN 5 NguyễnVănVỵ VÊn ®Ò cña thiÕt kÕ h−íng thñ tôc „D÷ liÖu lμ chung cho c¶ hÖ thèng Mäi thñ tôc thao t¸c trªn CSDL chung, ®Æc tr−ng cho tr¹ng th¸i toμn hÖ thèng Thao t¸c sai cña 1 thñ tôc lªn d÷ liÖu g©y sai lan truyÒn sang phÇn kh¸c sö dông dông d÷ liÖu nμy Söa ®æi 1 thñ tôc cã nguy c¬ ¶nh h−ëng tíi phÇn kh¸c liªn quan „ Thay ®æi cÊu tróc d÷ liÖu dÉn ®Õn thay ®æi tæng thÓ hÖ thèng Æ d÷ liÖu cÇn tæ chøc tèt „HÖ thèng lín, phøc t¹p: b¶o tr× khã kh¨n Bộ môn Công nghệ phần mềm – ĐHCN 6 NguyễnVănVỵ ThiÕt kÕ h−íng ®èi t−îng- OOD „ HiÖn ®ang trë nªn phæ biÕn „ Lμ mét c¸ch tiÕp cËn kh¸c, nh×n nhËn hÖ thèng theo c¸c quan ®iÓm:  tËp c¸c ®èi t−îng cã t−¬ng t¸c víi nhau  mçi ®èi t−îng bao gãi c¶ d÷ liÖu vμ c¸c xö lý trªn chóng  T−¬ng t¸c gi÷a c¸c ®èi t−êng b»ng truyÒn th«ng b¸o  C¸c ®èi t−îng cã thÓ kÕ thõa nhau Bộ môn Công nghệ phần mềm – ĐHCN 7 NguyễnVănVỵ VÝ dô kiÕn tróc h−íng ®èi t−îng issue () sendReminder () acceptPayment () sendReceipt () invoice# date amount customer Invoice invoice# date amount customer# Receipt invoice# date amount customer# Payment customer# name address credit period Customer Bộ môn Công nghệ phần mềm – ĐHCN 8 NguyễnVănVỵ ¦u ®iÓm cña OOD „ DÔ b¶o tr×: c¸c ®èi t−îng ®−îc hiÓu nh− c¸c thùc thÓ ho¹t ®éng ®éc lËp  Bao gãi th«ng tin  liªn kÕt láng lÎo (trao ®æi b»ng truyÒn th«ng b¸o) „ DÔ t¸i sö dông:  ®é ®éc lËp cao  cã kh¶ n¨ng kÕ thõa „ DÔ hiÓu: mét vμi hÖ thèng, cã sù ¸nh x¹ t−êng minh gi÷a thùc thÓ thùc thÕ giíi thùc vμ ®èi t−îng hÖ thèng Bộ môn Công nghệ phần mềm – ĐHCN 9 NguyễnVănVỵ Néi dung cña OOD „ X¸c ®Þnh c¸c tËp ®èi t−îng (gäi lμ líp) vμ c¸c ®Æc tr−ng cña chóng „ Ph©n ®Þnh vai trß vμ tr¸ch nhiÖm cña chóng trong hÖ thèng „ ThiÕt lËp ®−îc sù t−¬ng t¸c cña chóng ®Ó thùc hiÖn chøc n¨ng cña hÖ thèng phÇn mÒm ®Æt ra Bộ môn Công nghệ phần mềm – ĐHCN 10 NguyễnVănVỵ C¸c kh¸i niÖm cña OOD d1. §èi t−¬ng „ Lμ c¸c trõu t−îng hãa thùc thÓ cña thÕ giíi thùc hoÆc cña mét hÖ thèng „ Bao gåm: ®Þnh danh, c¸c thuéc tÝnh vμ c¸c ph−¬ng thøc thao t¸c trªn c¸c d÷ liÖu thuéc tÝnh cña n㠄 §éc lËp vμ ®ãng gãi tr¹ng th¸i thÓ hiÖn b»ng gi¸ trÞ c¸c thuéc tÝnh cña nã ë mét thêi ®iÓm „ Cung cÊo dÞch vô cho ®èi t−îng kh¸c hay yªu cÇu c¸c ®èi t−îng kh¸c thùc hiÖn mét dÞch vô Bộ môn Công nghệ phần mềm – ĐHCN 11 NguyễnVănVỵ Líp ®èi t−îng „ Líp ®èi t−îng lμ khu«n mÉu ®Ó t¹o ra tËp ®èi t−îng cã c¸c ®Æc tr−ng chung „ Líp ®èi t−îng cã thÓ kÕ thõa thuéc tÝnh vμ dÞch vô tõ líp ®èi t−îng kh¸c „ Líp ®−îc x¸c ®Þnh b»ng:  Tªn  Bé c¸c thuéc tÝnh  C¸c ph−¬ng thóc Sinh vien maSV hotenSV diachi lop Tao( ) Capnhat( ) Xoa( ) Bộ môn Công nghệ phần mềm – ĐHCN 12 NguyễnVănVỵ Trõu t−îng hãa „ Trõu t−îng hãa cung cÊp c¸i nh×n ®¬n gi¶n ®èi víi thùc thÓ cÇn xö lý  chØ m« t¶ c¸c tÝnh chÊt chóng ta quan t©m  che giÊu c¸c th«ng tin kh«ng cÇn thiÕt „§−îc cμi ®Æt nh− lμ:  kiÓu d÷ liÖu trõu t−îng, líp ®èi t−îng  c¸c kiÓu d÷ liÖu c¬ së cã s½n: int, double Bộ môn Công nghệ phần mềm – ĐHCN 13 NguyễnVănVỵ Bao gãi vμ che giÊu th«ng tin „ Lμ kh¸i niÖm c¬ së cña thiÕt kÕ/lËp tr×nh h−íng ®èi t−îng „Che giÊu th«ng tin ®Ó ®èi t−îng kh«ng cÇn thiÕt kh«ng thÓ sö dông „ChØ cung cÊp chøc n¨ng, dÞch vô cÇn „Che giÊu c¸c yÕu tè cã kh¶ n¨ng thay ®æi cÊu tróc d÷ liÖu c¸ch thøc cμi ®Æt Bộ môn Công nghệ phần mềm – ĐHCN 14 NguyễnVănVỵ CÊu tróc d÷ liÖu „M« t¶ mèi quan hÖ gi÷a c¸c kho¶n môc d÷ liÖu „CÊu tróc vËt lý chØ ra c¸ch thøc ch−¬ng tr×nh thao t¸c víi d÷ liÖu „C¸c cÊu tróc c¬ së  kho¶n môc v« h−íng  m¶ng (mét chiÒu, nhiÒu chiÒu)  danh s¸ch mãc nèi  c©y ph©n cÊp Bộ môn Công nghệ phần mềm – ĐHCN 15 NguyễnVănVỵ VÝ dô struct Date { int year, mon, day; }; struct Date { int year; int mon_and_day; } Bộ môn Công nghệ phần mềm – ĐHCN 16 NguyễnVănVỵ Tæng qu¸t hãa vμ kÕ thõa „ Mét líp cã thÓ lμ líp con cña 1 líp c¸c ®èi t−îng tæng qu¸ h¬n, vμ gäi lμ kÕ thõa cña líp tæng qu¸t „ trªn c©y kÕ thõa, líp cha (super class) cã thÓ lμ tæng qu¸t hãa cña 1 sè c¸c líp con (sub-class) „ Líp con kÕ thõa c¸c thuéc tÝnh vμ ph−¬ng thøc cña líp cha vμ cã thÓ thªm/thay ®æi ph−¬ng thøc, thuéc tÝnh „ Sö dông kÕ thõa gióp ta m« t¶ líp con chØ gåm c¸c ®Æc trung kh¸c líp cha Bộ môn Công nghệ phần mềm – ĐHCN 17 NguyễnVănVỵ VÝ dô c©y kÕ thõa Employee Programmer project progLanguage Manager Project Manager budgetsControlled dateAppointed projects Dept. Manager Strategic Manager dept responsibilities Bộ môn Công nghệ phần mềm – ĐHCN 18 NguyễnVănVỵ ¦u ®iÓm cña kÕ thõa „ Lμ c¬ chÕ trõu t−îng ®Ó ph©n lo¹i c¸c líp (thùc thÓ) „ T¸i sö dông c¶ ë møc thiÕt kÕ vμ møc lËp tr×nh  t¸i sö dông cÊu tróc d÷ liÖu  t¸i sö dông ph−¬ng thøc: ygiao diÖn ycμi ®Æt (m·) „ BiÓu ®å kÕ thõa lμ nguån th«ng tin mang tÝnh tæ chøc vÒ bμi to¸n Bộ môn Công nghệ phần mềm – ĐHCN 19 NguyễnVănVỵ T−¬ng t¸c gi÷a c¸c ®èi t−îng state o3 o3:C3 state o4 o4: C4 state o1 o1: C1 state o6 o6: C1 state o5 o5:C5 state o2 o2: C3 ops1() ops3 () ops4 () ops3 () ops1 () ops5 () Bộ môn Công nghệ phần mềm – ĐHCN 20 NguyễnVănVỵ T−¬ng t¸c gi÷a c¸c ®èi t−îng „ C¸c ®èi t−îng giao tiÕp b»ng trao ®æi th«ng b¸o „ Th«ng b¸o  Tªn dÞch vô ®−îc yªu cÇu  Th«ng tin dïng ®Ó thùc hiÖn dÞch vô „ C¸c lo¹i ®èi t−îng  actor: chØ göi th«ng b¸o  agent: göi vμ nhËn th«ng b¸o  server: chØ nhËn th«ng b¸o „ Thùc tÕ, th«ng b¸o ®−îc cμi ®Æt b»ng lêi gäi hμm  Tªn = tªn hμm  Th«ng tin = danh s¸ch tham sè Bộ môn Công nghệ phần mềm – ĐHCN 21 NguyễnVănVỵ Mét sè vÊn ®Ò dïng kÕ thõa „ §èi t−îng kh«ng tù chøa, kh«ng thÓ hiÓu nÕu kh«ng tham chiÕu ®Õn líp cha „ L¹m dông c¸c s¬ ®å kÕ thõa trong b−íc ph©n tÝch cã thÓ dÉn ®Õn sù kÐm hiÖu qu¶ Bộ môn Công nghệ phần mềm – ĐHCN 22 NguyễnVănVỵ KÕ thõa vμ OOD „ Cã hai quan niÖm 1. KÕ thõa lμ yÕu tè c¬ b¶n cña OOD vμ ®−îc cμi ®Æt th«ng qua c¸c ng«n ng÷ h−íng ®èi t−îng 2. KÕ thõa sö dông c¬ chÕ ®Æc biÖt ®Ó t¸i sö dông thuéc tÝnh vμ ph−¬ng thøc. ThiÕt kÕ kÕ thõa sÏ t¹o ra c¸c rμng buéc cho cμi ®Æt „ KÕ thõa kh«ng dÔ hiÓu vμ do ®ã nªn tr¸nh, nhÊt lμ ®èi víi c¸c hÖ thèng ®Æc biÖt quan träng. Bộ môn Công nghệ phần mềm – ĐHCN 23 NguyễnVănVỵ e. Ng«n ng÷ m« h×nh hãa thèng nhÊt Unified Modeling Language „ Là một ngôn ngữ mô hình để phát triển phần mềm hướmg đối tượng „Các đặc trưng: UML là ngôn ngữ: ƒ độ họa ƒ làm trực quan hóa ƒ đặc tả ƒ xây dựng mô hình ƒ làm tài liệu Bộ môn Công nghệ phần mềm – ĐHCN 24 NguyễnVănVỵ „Gåm 3 khèi cơ bản: A. C¸c sù vËt (things) 1. C¸c sù vËt cÊu tróc (structural) 2. C¸c sù vËt hμnh vi (behavioral) 3. C¸c sù vËt nhãm gép(grouping) 4. C¸c sù vËt gi¶i thÝch (annotational) B. C¸c quan hÖ (Relationships) C. C¸c biểu ®å (Diagrams) Ng«n ng÷ m« h×nh hãa thèng nhÊt Bộ môn Công nghệ phần mềm – ĐHCN 25 NguyễnVănVỵ Ng«n ng÷ m« h×nh hãa thèng nhÊt „ C¸c sù vËt cÊu tróc (structural) Class –lớp use ase –ca sử dụng Collaboration sù cộng t¸c Node - nótActor Interface Component-thμnhfần Đặt hàng Window origin open() Đặt hàng orderform.java Server Bộ môn Công nghệ phần mềm – ĐHCN 26 NguyễnVănVỵ Ng«n ng÷ m« h×nh hãa thèng nhÊt „ C¸c sù vËt hμnh vi , nhãm gép, gi¶i thÝch interaction state machine package Note display ®îi + OrderForm + Tracking FormOrde Client Class Tù t¹o Bộ môn Công nghệ phần mềm – ĐHCN 27 NguyễnVănVỵ Ng«n ng÷ m« h×nh hãa thèng nhÊt B. C¸c mèi quan hÖ dependence assosiation generalization compositerealization aggregation 0..1 1..* Bộ môn Công nghệ phần mềm – ĐHCN 28 NguyễnVănVỵ Ng«n ng÷ m« h×nh hãa thèng nhÊt C. C¸c biÓu ®å Gäi®iÖntho¹i ®Æt héi nghi Tr¶lêi “use” “extend” BiÓu ®å cửa sa sö dông Bộ môn Công nghệ phần mềm – ĐHCN 29 NguyễnVănVỵ Ng«n ng÷ m« h×nh hãa thèng nhÊt C. C¸c biÓu ®å BiÓu ®å cửa c«ng t¸c ph©n tÝch GiaodiÖn róttiÒn GiaodiÖnnhËntiÒn tμi kho¶n lÞch sö tμi kho¶n ®iÒu khiÓn rót tiÒn Bộ môn Công nghệ phần mềm – ĐHCN 30 NguyễnVănVỵ TransportAgent Message IncomingQueue OutgoingQueue Queue c:company d1:Department name =“Sale” d2:Department name=“R&D” d3:Department name = “US Sales” p: Person name=“Exin” BiÓu ®å líp BiÓu ®å ®èi t−îng Ng«n ng÷ m« h×nh hãa thèng nhÊt Bộ môn Công nghệ phần mềm – ĐHCN 31 NguyễnVănVỵ C. C¸c biÓu ®å BiÓu ®å tuÇn tù :message :OutgoingQueue create ad dMessage :TranAgent RemoveMessage Ng«n ng÷ m« h×nh hãa thèng nhÊt Bộ môn Công nghệ phần mềm – ĐHCN 32 NguyễnVănVỵ C. C¸c biÓu ®å waiting GettingToken GettingBody BiÓu ®å tr¹ng th¸i Ng«n ng÷ m« h×nh hãa thèng nhÊt Bộ môn Công nghệ phần mềm – ĐHCN 33 NguyễnVănVỵ Ph©n tÝch/thiÕt kÕ h−íng ®èi t−îng „M« h×nh ph©n tÝch  M« h×nh nghiÖp vô yM« h×nh miÒn yBiÓu ®å ho¹t ®éng  M« h×nh ca sö dông  M« h×nh líp ph©n tÝch  M« h×nh gãi líp „M« h×nh thiÕt kÕ ƒM« h×nh cÊu tróc gãi ƒM« h×nh céng t¸c ƒM« h×nh líp ƒ ®Æc t¶ líp, giao diÖn Bộ môn Công nghệ phần mềm – ĐHCN 34 NguyễnVănVỵ TiÕn tr×nh ph©n tÝch-thiÕt kÕ DT TiÕn tr×nh ph©n tÝch vμ thiÕt kÕ h−íng ®èi t−îng M« t¶ nghiÖp vô LËp m« h×nh ca sö dông LËp m« h×nh kiÕn tróc-gãi ca sö dông Ph©n tÝch 1 gãi ca sö dông Ph©n gãi c¸c líp ph©n tÝch ThiÕt kÕ hÖ thèng LËp biÓu ®å c«ng t¸c 1 gãi ph©n tÝch X©y dùng c¸c giao diÖn LËp biÓu ®å líp thiÕt kÕ ThiÕt kÕ líp ThiÕt kÕ CSDL ThiÕt kÕ giao diÖn sö dông NghiÖp vô Ph©n tÝch ThiÕt kÕ Bộ môn Công nghệ phần mềm – ĐHCN 35 NguyễnVănVỵ Ph©n tÝch h−íng ®èi t−îng 1.M« t¶ nghiÖp vô ƒ B»ng lêi ƒ B»ng biÓu ®å ho¹t ®«ng 2.X©y dùng m« h×nh nghiÖp vô ƒ M« h×nh miÒn lÜnh vùc ƒ M« h×nh ca sö dông 3.Ph©n tÝch x¸c ®Þnh cÊu tróc (khëi th¶o) ƒ Lμm mÞn m« h×nh ca sö dông ƒ X¸c ®Þnh c¸c gãi ca sö dông, giao diÖn Bộ môn Công nghệ phần mềm – ĐHCN 36 NguyễnVănVỵ 1.Ph©n tÝch mét ca sö dông ƒ T×m c¸c líp ph©n tÝch ƒ X¸c ®Þnh liªn kÕt gi÷a c¸c líp 2.Ph©n gãi l¹i c¸c líp ph©n tÝch (t¨ng c−êng kiÕn tróc) ƒ T¸ch c¸c líp dÞch vô & øng dông ƒ Ph©n gãi c¸c líp ph©n tÝch theo tÇng 3.X¸c ®Þnh vμ m« t¶ c¸c giao diÖn ƒ X¸c ®inh giao diÖn gi÷a c¸c gãi ƒ X¸c ®Þnh liªn kÕt gi÷a c¸c gãi Ph©n tÝch h−íng ®èi t−îng Bộ môn Công nghệ phần mềm – ĐHCN 37 NguyễnVănVỵ ThiÕt kÕ h−íng ®èi t−îng 1.ThiÕt kÕ biÓu ®å t−¬ng t¸c mçi gãi ƒ X¸c ®Þnh l¹i c¸c líp ƒ X©y dùng biÓu ®å t−¬ng t¸c 2.Ph¸t triÓn biÓu ®å líp thiÕt kÕ ƒ ChuyÓn biÓu ®å c«ng t¸c sang biÓu ®å líp ƒ Hoμn thiÖn c¸c quan hÖ c«ng t¸c 3.ThiÕt kÕ c¸c líp ƒ ThiÕt kÕ c¸c thuéc tÝnh ƒ ThiÕt kÕ c¸c ph−¬ng thøc ƒ ThiÕt kÕ CSDL 4.ThiÕt kÕ giao diÖn ng−êi dïng Bộ môn Công nghệ phần mềm – ĐHCN 38 NguyễnVănVỵ VÝ dô: ph©n tÝch h−íng ®èi t−îng 1.Bμi to¸n: giao dÞch tÝn dông sö dông m¸y ATM 2.M« h×nh nghiÖp vô Giao dÞch tÝn dông göi tiÒn rót tiÒn ChuyÓn tiÒn BiÓu ®å ca sö dông M« h×nh miÒn ng©n hµng tµi kho¶nkh¸ch dÞch vô 1 1..*1..* 1 1..* 1 1 11 1..* Bộ môn Công nghệ phần mềm – ĐHCN 39 NguyễnVănVỵ „ X¸c ®Þnh gãi c¸c ca sö dông göi tiÒn BiÓu ®å gãi ca sö dông göi tiÒngöi tiÒn Giao dÞch tÝn dông VÝ dô: ph©n tÝch h−íng ®èi t−îng Bộ môn Công nghệ phần mềm – ĐHCN 40 NguyễnVănVỵ „ Ph©n tÝch mét gãi c¸c ca sö dông M« hinh ca sử dụng M« h×nh ph©n tÝch rót tiền thực thi ca sử dụng rót tiền > M¸y trả tiền giao diện thủ quỹ điều khiển rut tiền tài khoản C¸c lớp ph©n tÝch thực thi ca sử dụng rót tiền. VÝ dô: ph©n tÝch h−íng ®èi t−îng Bộ môn Công nghệ phần mềm – ĐHCN 41 NguyễnVănVỵ „ BiÓu ®å ph©n tÝch mét gãi ca sö dông C¸c líp ph©n tÝch vμ quan hÖ gi÷a chóng Tµi khoản giao diện thủ quỹ điều khiển rót tiền M¸y trả tiền Kh¸ch hµng VÝ dô: ph©n tÝch h−íng ®èi t−îng Bộ môn Công nghệ phần mềm – ĐHCN 42 NguyễnVănVỵ giao diện thủ quỹ điều khiển chuyển tiền M¸y trả tiền M¸y nhận tiền điều khiển nhận tiền điều khiển rót tiền chuyển đổi tμi khoản Tμi khoản C¸c gãi cña c¸c líp ph©n tÝch kh¸ch hμng „ BiÓu ®å gãi c¸c líp ph©n tÝch VÝ dô: ph©n tÝch h−íng ®èi t−îng Bộ môn Công nghệ phần mềm – ĐHCN 43 NguyễnVănVỵ „ ThiÕt kÕ hÖ thèng M¸y kh¸ch M¸y dịch vụ ứng dụng M¸y dịch vụ ng©n hµng internet intranet Biểu đồ bố trÝ c¸c nót của hệ thống kh¸ch hµng VÝ dô: Thiết kế h−íng ®èi t−îng Bộ môn Công nghệ phần mềm – ĐHCN 44 NguyễnVănVỵ „ BiÓu ®å c¸c líp thiÕt kÕ Mµn h×nh hiển thị Bµn phÝm M¸y đọc thẻ cảm ứng trả tiền M¸y đẩy tiền M¸y đếm tiền rót tiền quản lý giao dịch Tµi khoản lịch sủ tµi khoản quản lý tµi khoản quản lý kh¸ch C¸c lớp thiÕt kÕ tham gia thực hiện ca sử dụng rót tiền VÝ dô: Thiết kế h−íng ®èi t−îng Bộ môn Công nghệ phần mềm – ĐHCN 45 NguyễnVănVỵ : quản lý giao dịch đưa thẻ vμo Th«ng tin thẻ (ID) Yªu cầu hiển thi PIN hiện bảng yªu cầu nhập vμo m· PIN hiện bảng yªu cầu nhập vμo số tiền rót Yªu cầu số tiền rót số tiền (A) Yªu cầu số tiền mặt (A) Yªu cầu giảm số dư = (A) đề nghi x¸c nhận PIN m· PIN Biểu đồ tuần tự thực hiện ca sử dụng rót tiền : khách hàng : máy đếm tiền : quản lý khách : màn hình hiển thi : máy đọc thẻ : bàn phím VÝ dô: Thiết kế h−íng ®èi t−îng Bộ môn Công nghệ phần mềm – ĐHCN 46 NguyễnVănVỵ „ThiÕt kÕ líp: tμi kho¶n a. Bảng c¸c thuộc tÝnh : Tªn thuéc tÝnh kiÓu Néi dung IDtaikh string §Þnh danh tμi kho¶n sotkh string Số tμi khoản dμnh cho một kh¸ch hμng gåm ch÷, sè, dÊu sodu money Sè d− cã trong tμi khoản, ®¬n vị ®o lμ tiền tệ VÝ dô: Thiết kế h−íng ®èi t−îng Bộ môn Công nghệ phần mềm – ĐHCN 47 NguyễnVănVỵ „ThiÕt kÕ líp: Tμi kho¶n b. Bảng c¸c thao t¸c (t¸c vụ) Tªn thao t¸c ý nghĩa taolap() Tạo một tài khoản cho kh¸ch hàng mới gui() Bổ sung tiền gửi vào tài khoản chuyen() Chuyển một số tiền từ 1 tài khoản sang 1 tài khoản kh¸c rut() Rót một số tiền từ tài khoản dong() Đãng tài khoản VÝ dô: Thiết kế h−íng ®èi t−îng Bộ môn Công nghệ phần mềm – ĐHCN 48 NguyễnVănVỵ „ ThiÕt kÕ líp Lớp tμi khoản với c¸c thuộc tÝnh vμ c¸c thao t¸c taolap (sotkh:string, sotien;money) + gui(sotkh:string, soien:money) + chuyen(sotkh:stringk, sotien:money, sotkh2:string) + rut (sotk:h:string, sotien;money) dong() Taikhoan IDtaikh:string sotaikh: string sodu: money VÝ dô: Thiết kÕ h−íng ®èi t−îng Bộ môn Công nghệ phần mềm – ĐHCN 49 NguyễnVănVỵ MÉu thiÕt kÕ - Pattern „ MÉu thiÕt kÕ: Pattern ƒ khi thiÕt kÕ cã nhiÒu tr−êng hîp cã sù t−¬ng tù ƒ M« t¶ gi¶i ph¸p cña mét tr−êng chung cã thÓ ¸p cho tr−êng hîp kh¸c t−¬ng tù  gäi lμ mÉu thiÕt kÕ „ M« t¶ mét mÉu bao gåm: ƒ VÊn ®Ò ®Æt ra (ng÷ c¶nh) ƒ Gi¶i ph¸p: ph¸t biÓu nh− mét ch©m ng«n ƒ KÕt qu¶ ƒ C¸c mÉu liªn quan ƒ M« h×nh mÉu Bộ môn Công nghệ phần mềm – ĐHCN 50 NguyễnVănVỵ VÝ dô mét sè mÉu thiÕt kÕ „ B¶n chÊt mÉu ™ MÉu thiÕt kÕ kh«ng ph¶i lμ c¸i g× míi mÎ ™ MÉu thiÕt kÕ lμ mét sù ®óc kÕt tõ kinh nghiÖm „ 5 mẫu phần mềm g¸n tr¸ch nhiệm chung GRASP thường được sử dụng nhiều nhất lμ: ƒ Expert (chuyªn gia) ƒ Creator (bộ tạo lập) ƒ Low Coupling (ghÐp nối thấp) ƒ HighCohension (kết dÝnh cao) ƒ Controller (bộ điều khiển) „ Bộ môn Công nghệ phần mềm – ĐHCN 51 NguyễnVănVỵ VÝ dô mét sè mÉu thiÕt kÕ „ M« h×nh mÉu cña mÉu chuyªn gia ƒ VÊn ®Ò: Nguyªn t¾c g¸n tr¸ch nhiÖm cho 1 ®èi t−¬ng lμ g×? ƒ Gi¶i ph¸p: H·y g¸n tr¸ch nhiÖm cho ®èi t−îng cã ®ñ th«ng tin ®Ó thùc hiÖn tr¸chnhiÖm ®ã ƒ KÕt qu¶: Gi¶m sù phô thuéc vμo líp kh¸c ƒ MÉu liªn quan: kÕt dÝnh cao, ghÐp nèi láng Bộ môn Công nghệ phần mềm – ĐHCN 52 NguyễnVănVỵ VÝ dô mét sè mÉu thiÕt kÕ „ M« h×nh mÉu chuyªn gia: bμi to¸n b¸n hμng ƒ G¸n tr¸ch nhiÖm cho mathangban tÝnh tæng tiÒn b¸n 1 mÆt hμng tienIterm(upc, soluong) v× nã cã th«ng tin soluong vμ lÊy gi¸ tõ danhmuc ƒ G¸n tr¸ch nhiÖm cho lanban tÝnh tæng tiÒn mét lÇn b¸n tongtien(sott) v× nã biÕt sè tiÒn tõng mÆt hμng thuéc lÇn b¸n lanban sott: int ngay: date taoSale( ) tongtien(sott) mathangban upc: string sott: int soluong: int taoIterm( ) tienIterm(upc,soluong,p) danhmuc upc: string mota: string gia: int taoDM( ) layGia(upc) Bộ môn Công nghệ phần mềm – ĐHCN 53 NguyễnVănVỵ Lîi Ých sö dông mÉu thiÕt kÕ ƒ Cho ta gi¶i ph¸p cña vÊn ®Ò kh«ng cÇn t×m kiÕm ƒ Dïng l¹i c¸i ®· cã, ®ì tèn thêi gian vμ c«ng søc ƒ Cho thiÕt kÕ tèt vμ chÊt l−îng hÖ thèng cao Bộ môn Công nghệ phần mềm – ĐHCN 54 NguyễnVănVỵ C©u hái và thảo luận

Các file đính kèm theo tài liệu này:

  • pdfUnlock-3cSEV_thietkeDT.pdf