這次帶給大家PHP里氏替換原則實戰分析,PHP里氏替換原則使用的注意事項有哪些,下面就是實戰案例,一起來看一下。
替換原則由MIT電腦科學實驗室的Liskov女士在1987年的OOPSLA大會上的一篇文章中提出,主要闡述有關繼承的一些原則,故稱里氏替換原則。
2002年,Robert C.Martin出版了一本名為《Agile Software Development Principles Patterns and Practices》的書,在書中他把里氏替換原則最終簡化成一句話:「Subtypes must be substitutable for their base types」(子類別必須能夠替換成它們的基底類別。)
1. LSP的內容
里氏替換原則(Liskov Substitution Principle , LSP)的定義和主要想法如下:由於物件導向程式設計技術中的繼承在具體的程式設計中過於簡單,在許多系統的設計和程式實作中,我們並沒有認真地、理性地思考應用系統中各個類別之間的繼承關係是否合適,派生類別是否能正確地對其基底類別中的某些方法進行重寫等問題。因此經常出現濫用繼承或錯誤地進行了繼承等現象,為系統的後期維護帶來了不少麻煩。這就需要我們有一個設計原則來遵循,它就是替換原則。
LSP指出:子類別類型必須能夠替換掉它們的父類型、並出現在父類別能夠出現的任何地方。它指導我們如何正確地進行繼承和派生,並合理地重複使用程式碼。此原則認為,一個軟體實體如果使用一個基類的話,那麼一定適用於其子類,而且這根本不能察覺出基類對象和子類對象的區別。想一想,是不是跟多態的概念比較像?
2. LSP主要是針對繼承的設計原則
因為繼承與衍生是OOP的一個主要特性,能夠減少程式碼的重複程式實現,從而實現系統中的程式碼復用,但是如何正確地進行繼承設計和合理地應用繼承機制呢?
這就是LSP所要解決的問題:
如何正確地進行繼承方面的設計?
最佳的繼承層次如何取得?
怎麼樣避免所設計的類別層次陷入不符合OCP原則的狀況?
那要如何遵守該設計原則呢?
1)父類別的方法都要在子類別中實作或重寫,而衍生類別只實作其抽象類別中宣告的方法,而不應給出多餘的方法定義或實作
2)在客戶端程式中只應該使用父類別物件而不應直接使用子類別對象,這樣可以實現運行期綁定(動態多態)。
如果A、B兩個類別違反了LSP的設計,通常的做法是創建一個新的抽象類別C,作為兩個具體類別的超類,獎A和B的共同行為移動到C中,從而解決A和B的行為不完全一致的問題。
不過PHP對LSP的支持並不好,缺乏向上轉型等概念,只能透過一些曲折的方法來實現。對於這個原則,這裡就不細講了。
下面給出一個快取的實作接口,用抽象類別做基類,遵循LSP實現其設計。
<?php abstract class Cache { /** * 设置一个缓存变量 * @param $key 缓存key * @param $value 缓存内容 * @param int $expire 缓存时间(秒) * @return boolean 是否缓存成功 */ public abstract function set($key, $value, $expire = 60); /** * 获取一个已经缓存的 * @param $key 缓存key * @return mixed 缓存内容 */ public abstract function get($key); /** * 删除一个已经缓存的变量 * @param $key 缓存key * @return boolean 是否删除成功 */ public abstract function del($key); /** * 删除全部缓存变量 * @return boolean 是否删除成功 */ public abstract function delAll(); /** * 检测是否存在对应的缓存 * @param $key 缓存key * @return boolean 是否存在 */ public abstract function has($key); }
如果現在要求實作檔案、memcache、accelerator等各種機制下的緩存,只需要繼承這個抽象類別並實作其抽象方法。
相信看了本文案例你已經掌握了方法,更多精彩請關注php中文網其它相關文章!
推薦閱讀:
以上是PHP里氏替換原則實戰分析的詳細內容。更多資訊請關注PHP中文網其他相關文章!