跳到主要內容

SRP

SRP:Single Responsibility Principle 單責任原則

定義為:要變更類別的原因只能有一個。

乍聽之下很怪異,用人類聽得懂的話解釋,就是說類別只管自己的事,不是自己的別攬在身上。Agile那本舉的第一個例子很爛,用Modem舉例一點都不直覺?我舉個好例子:Employee。在所有的人事系統中應該都有這個類別,而Employee除了自己的基本資料外,遇到繳稅時要算Tax,沒經驗時會加一個calcTax的method,但有經驗的人就知道必須另外做一個Tax類別;Employee資料的persistence應該有EmployeeDAO之類的Class處理。再參考昨天講的OCP就知道Employee應該是個interface,而不是class。

SRP容易瞭解,卻是最容易犯錯的原則;善用refactoring與pattern能夠讓我們消除程式裏的bad smell。

參考資料:
http://www.objectmentor.com/resources/articles/srp
http://www.answers.com/topic/single-responsibility-principle

留言

這個網誌中的熱門文章

Personal Bookmark

Java SE 6 + Firefox 2 UI 問題 As I do . Google拋棄了了SOAP API,浮想聯翩 https://www.gandi.net/ VS 2005 SP1中文版推出 Windows Vista中文版下載 ASP.NET 2.0網頁執行管線與快取原理 Cache 2.0快取架構與快取資料自動移除架構圖 flickr sync 分享與試用 SUN Looking Glass 3D圖形介面發布1.0 雅虎勵精圖治推動改革 Wait and see 國內某SOC疑遭駭客入侵 大砲開講 Very Important! 微軟公佈Vista安全程式介面草案 一窺Google開原碼庫房乾坤 qing is writing a dig girl net... wait and see

DBeaver 介面語言

DBeaver是我個人頗常用的一套跨平台Database管理工具,最近升級後發現Windows版本居然變成簡體中文,而且無法切換為英文。

自然人憑證讀卡機驅動程式

鳥毅用的是第一代的自然人憑證讀卡機,EZ100PU(後來有同事買EZmini可以讀SIM卡似乎更好),每年報稅時用一次。 本來只是要申請些政府業務,一時之間找不到光碟,沒想到在 驅動程式下載 居然看到Linux和Mac的驅動程式,剩下的就是政府單位的網頁和程式應該改版了吧!!!