Tài liệu Nguyên lý thiết kế và mẫu thiết kế docx

48 855 12
Tài liệu Nguyên lý thiết kế và mẫu thiết kế docx

Đang tải... (xem toàn văn)

Tài liệu hạn chế xem trước, để xem đầy đủ mời bạn chọn Tải xuống

Thông tin tài liệu

Nguyên thiếtkế mẫuthiếtkế Nguyên thiếtkế… 2 NguyễnViệtHà Nội dung  Thiết kế module  Chất lượng thiết kế  Độ đo thiết kế tốt  Khái niệm về mẫu thiết kế Nguyên thiếtkế… 3 NguyễnViệtHà Tài liệu tham khảo  Bruce Eckel, Thinking in Patterns  Erich Gamma, Design Patterns – Elements of Reusable Object-Oriented Software Nguyờn thitk 4 NguynVitH Thit k module Dựa trên quan điểm "chia để trị" C(p1 + p2) > C(p1) + C(p2) E(p1 + p2) > E(p1) + E(p2) C: độ phức tạp E: nỗ lực thực hiện giảm độ phức tạp cục bộ, dễ sửa đổi có khả n ng phát triển song song dễ sửa đổi, dễ hiểu nên dễ tái sử dụng Nguyên thiếtkế… 5 NguyễnViệtHà Số lượng module CÇn x¸c ®Þnh sè m«®un tèi −u gi¸ phÇn mÒm sè module sè module tèi −u chi phÝ ph¸t triÓn module chi phÝ tÝch hîp Nguyờn thitk 6 NguynVitH Chất lợng = Che giấu thông tin Sử dụng module thông qua các giao diện tham số giá trị trả lại Không cần biết cách thức cài đặt thực tế thuật toán cấu trúc d liệu giao diện ngoại lai (các mô đun thứ cấp, thiết bị vào/ra) tài nguyên hệ thống Nguyờn thitk 7 NguynVitH Che giấu thụng tin: do Giảm hiệu ứng phụ khi sửa đổi module Giảm sự tác động của thiết kế tổng thể lên thiết kế cục bộ Nhấn mạnh việc trao đổi thông tin thông qua giao diện Loại bỏ việc sử dụng d liệu dùng chung Hớng tới sự đóng gói chức nng - thuộc tính của thiết kế tốt Tạo ra các sản phẩm phần mềm tốt hơn Nguyờn thitk 8 NguynVitH Chất lợng thiết kế Phụ thuộc bài toán, không có phơng pháp tổng quát Một số độ đo Coupling: mức độ ghép nối gia các module Cohesion: mức độ liên quan lẫn nhau của các thành phần bên trong một module Understandability: tính hiểu đợc Adaptability: tính thích nghi đợc Nguyờn thitk 9 NguynVitH Coupling and Cohesion Coupling (ghép nối) độ đo sự liên kết (trao đổi d liệu) gia các mô đun ghép nối chặt chẽ thỡ khó hiểu, khó sửa đổi (thiết kết tồi) Cohesion (kết dính) độ đo sự phụ thuộc lẫn nhau của các thành phần trong một module kết dính cao thỡ tính cục bộ cao (độc lập chức nng); dễ hiểu, dễ sửa đổi Nguyên thiếtkế… 10 NguyễnViệtHà Coupling  møc ®é quan hÖ cña c¸c module  module nªn ghÐp nèi láng lÎo  cµng láng lÎo cµng dÔ söa ®æi thiÕt kÕ normal coupling loose and best data coupling still very good stamp coupling ok control coupling ok common coupling very bad content coupling tight and worst [...]... Nguyờn thit k 19 Understandability Tính hiểu đợc Ghép nối lỏng lẻo Kết dính cao ợc lập tài liệu Thuật toán, cấu trúc dễ hiểu Nguyn Vit H Nguyờn thit k 20 Thiết kế hớng đối tợng Thiết kế hớng đối tợng hớng tới chất lợng thiết kế tốt đóng gói, che dấu thông tin là các thực thể hoạt động độc lập trao đổi d liệu qua thông điệp có khả nng kế thừa cục bộ, dễ hiểu, dễ tái sử dụng Nguyn Vit H Nguyờn thit... cho thiết kế khó hiểu, khó sửa đổi, dễ nhầm printRecord (name, sex) printName Nguyn Vit H Nguyờn thit k 13 Ghép nối nhãn (stamp coupling) Các module trao đổi thừa thông tin Module có thể thực hiện chức nng ngoài ý muốn Làm giảm tính thích nghi (age) (personel record) calcAge Nguyn Vit H Nguyờn thit k 14 Ghép nối d liệu (data coupling) Truyền d liệu qua tham số Nhận kết quả qua tham số và. .. cohesion) - các thành phần không liên quan đến nhau Kết dính lô gic (logical cohesion) - các thành phần làm chức nng lô gic tơng tự - vd: hàm xử lỗi chung Kết dính thời điểm (temporal cohesion) - các thành phần hoạt động cùng thời điểm - vd: hàm khởi tạo (đọc d liệu, cấp phát bộ nhớ ) Nguyn Vit H Nguyờn thit k 17 Các chủng loại kết dính Kết dính thủ tục (procedural cohesion) - các thành phần... bản, tính phụ cấp, tính bảo hiểm Kết dính truyền thông (communicational cohesion) - các thành phần truy cập cùng d liệu - vd: thống (tính max, min, mean, variation ) Nguyn Vit H Nguyờn thit k 18 Các chủng loại kết dính Kết dính tuần tự (sequential cohesion) - output của một thành phần là input của thành phần tiếp theo - vd: ảnh mầu -> đen trắng -> ảnh nén Kết dính chức nng (functional cohesion)... nhất Các module dùng lẫn d liệu của nhau - các ngôn ng bậc thấp không có biến cục bộ - lạm dụng lệnh Goto Nguyn Vit H Nguyờn thit k 11 Ghép nối chung (common coupling) Các module trao đổi d liệu thông qua biến tổng thể Lỗi của module này có thể ảnh hởng đến hoạt động của module khác Khó sử dụng lại các module mô đun gây lỗi B A mô đun gặp lỗi C D liệu Nguyn Vit H Nguyờn thit k 12 Ghép nối điều... calcDayOfWeek Nguyn Vit H Nguyờn thit k 15 Cohesion mỗi module chỉ nên thực hiện một chức nng mọi thành phần nên tham gia thực hiện chức nng đó Nguyn Vit H functional sequential communicational procedural temporal logical high and best ok still ok not bad at all still not bad at all still not bad at all coincidental lowest and worst by far Nguyờn thit k 16 Các chủng loại kết dính Kết dính gom góp (coincidental... new WinWindow(args); } } Nguyn Vit H Nguyờn thit k 28 Gii phỏp (tt) Chn h lp mun dựng: WidgetFactory wf = new WinWidgetFactory(); Khi khi to i tng, khụng dựng "new" m gi: Button b = wf.makeButton(args); Thay i h i tng - ch mt ln trong mó ci t! Thờm h - thờm mt factory, khụng nh hng ti mó ang tn ti! Nguyn Vit H Nguyờn thit k 29 S lp Nguyn Vit H Nguyờn thit k 30 ng dng Cỏc h iu hnh khỏc nhau... ng cu hỡnh ca i tng Nguyn Vit H Nguyờn thit k 24 Abstract Factory Mt chng trỡnh cn cú kh nng chn mt trong mt vi h cỏc lp i tng Vớ d, giao din ha nờn chy c trờn mt vi mụi trng Mi mụi trng (platform) cung cp mt tp cỏc lp ha riờng: WinButton, WinScrollBar, WinWindow MotifButton, MotifScrollBar, MotifWindow pmButton, pmScrollBar, pmWindow Nguyn Vit H Nguyờn thit k 25 Yờu cu Thng nht thao tỏc vi... ngha giao din (interfaces): Thng nht cỏch thc to i tng D dng thay i cỏc h lp i tng D dng thờm h mi Nguyn Vit H Nguyờn thit k 26 Gii phỏp nh ngha Factory - lp to i tng: class WidgetFactory { Button makeButton(args) = 0; Window makeWindow(args) = 0; // other widgets } Nguyn Vit H Nguyờn thit k 27 Gii phỏp (tt) nh ngha Factory chi tit cho tng h lp i tng: class WinWidgetFactory extends WidgetFactory... với xu hớng tái sử dụng Nguyn Vit H Nguyờn thit k 22 Adaptability (2) Cỏc chc nng cn c thit k sao cho d dng m rng m khụng cn sa cỏc mó ó cú (Open closed principle) Tru tng húa l chỡa khúa gii quyt vn ny cỏc chc nng tru tng húa thng bt bin cỏc lp dn xut ci t cỏc gii phỏp c th s dng a hỡnh Mu thit k: l thit k chun cho cỏc bi toỏn thng gp Nguyn Vit H Nguyờn thit k 23 Mu thit k (Design Patterns) . Nguyên lý thiếtkế và mẫuthiếtkế Nguyên lý thiếtkế… 2 NguyễnViệtHà Nội dung  Thiết kế module  Chất lượng thiết kế  Độ đo thiết kế tốt  Khái. lượng thiết kế  Độ đo thiết kế tốt  Khái niệm về mẫu thiết kế Nguyên lý thiếtkế… 3 NguyễnViệtHà Tài liệu tham khảo  Bruce Eckel, Thinking in Patterns

Ngày đăng: 17/12/2013, 09:15

Từ khóa liên quan

Tài liệu cùng người dùng

Tài liệu liên quan