跳到主要內容

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

留言

這個網誌中的熱門文章

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

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

DBeaver 介面語言

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

如何將較高版本SQL Server複製到低版本SQL Server (降級為舊版)並保留權限及資料庫圖表

一般若是要將SQL Server裡的Database轉往其他Server時,最簡單的方式就是備份(Backup)後再還原(Restore),或者是䣃離(detach)後附加(attach)。 但是很不幸地,若是由較低版本(e.g. 2008)到較高版本(e.g. 2012)要怎麼辦呢?