本文是從 S.O.L.I.D. Class Design Principles 這篇文章翻譯而來。
本文是由敏捷宣言簽署人之一、《 Clean Code(代碼整潔之道)》一書的作者Robert C. Martin為他的《Applying Principles and Patterns》這本書搜集整理而來。
只有一個理由去修改一個類。例如,如果一個業務規則的改變會導致這個類的修改,那么,數據庫、界面、報表格式或系統任何其它的部分的改變都不該迫使這個類做修改。
軟件構成(類,模塊,方法等)向擴展行為開放,向修改行為關閉。
子類必須能夠用來當作基類使用。如果類A繼承類B,任何能使用A的地方,B也同樣可以使用。例如,是否還記得,正方形可以看作是矩形!當進行擴展 時:前提條件不許繞過,后置條件不能放寬限制,可見常量不能被修改(?)。常量:在擴展之前或之后,用戶都需要依靠這個常量來傳遞信息。正確的使用set 形式的繼承關系。不遵守set語義是非常危險的。歸納:使用超類的引用的任何上下文中也可以使用其子類的引用替代。這個原則極大的限制了在純擴展(繼承) 機制里可以做的事情。不遵守會帶來風險。
一個類對另一個類的依賴應該限制在最小化的接口上。
依賴抽象層(接口),而不是具體類。
也被稱做封鎖信息原則:只跟朋友交流
一個對象O的任何一個方法M只能調用下列類型的對象的方法:
參考
不要調用我,我會調用你的。
去掉重復代碼。
反向依賴的另外一種說法。
不要添加你“認為以后可能有用”的代碼。只在“事到臨頭”時才添加代碼。
讓它能工作的最簡單的方法是什么?
Powered by: C++博客 Copyright © RTY