跳到主要內容

LSP : Liskov Substitution Principle

LSP (Liskov Substitution Principle) 簡單的說就是:子類別必須能取代父類別

我在寫Class與Instance的本質時忘了這叫什麼(又不是考試,誰會記得啥Liskov),但依我十多年C++的經驗,遵守LSP才會讓程式的責任歸屬分明。Agile PPP這本書舉的例子是Rectangle與Square,我就不細說。舉個好懂的例子(但設計得很差,臨時想不到好例子):Employee,Employee是class,而AEmployee是A公司用的Employee子類別。設計Employee的人當初有一個store的method,但AEmployee是存在SQLServer,因此store就傳回false。結果在A公司專案的主系統呼叫到store時,就發生錯誤。明眼人一看就知道,應該把Employee設計成介面,並且把Business與Data分開,這個就不談。

我的意思是:違反LSP確實很危險,在大型專案不注意就會產生奇怪的錯誤。設計子類別時一定要遵守LSP,若一定會違反,則要改變設計,這個時候應該要優先考慮:組合/聚合重複使用原則(Composition/Aggregation Principle ; CARP)

CARP比較簡單,就是儘量使用合成/聚合,少用繼承。能夠用HAS-A就不要用IS-A。

留言

這個網誌中的熱門文章

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

鳥毅用的是第一代的自然人憑證讀卡機,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)要怎麼辦呢?