S.O.L.I.D.類設計原則

來源: aqee  發布時間: 2011-05-06 15:21  閱讀: 4360 次  推薦: 4   原文鏈接   [收藏]  

  本文是從 S.O.L.I.D. Class Design Principles 這篇文章翻譯而來。

  本文是由敏捷宣言簽署人之一、《 Clean Code(代碼整潔之道)》一書的作者Robert C. Martin為他的《Applying Principles and Patterns》這本書搜集整理而來。

  單一責任原則(SRP)

  只有一個理由去修改一個類。例如,如果一個業務規則的改變會導致這個類的修改,那么,數據庫、界面、報表格式或系統任何其它的部分的改變都不該迫使這個類做修改。

  開發/關閉原則(OCP)

  軟件構成(類,模塊,方法等)向擴展行為開放,向修改行為關閉。

  Liskov替換原則(LSP)

  子類必須能夠用來當作基類使用。如果類A繼承類B,任何能使用A的地方,B也同樣可以使用。例如,是否還記得,正方形可以看作是矩形!當進行擴展時:前提條件不許繞過,后置條件不能放寬限制,可見常量不能被修改(?)。常量:在擴展之前或之后,用戶都需要依靠這個常量來傳遞信息。正確的使用set形式的繼承關系。不遵守set語義是非常危險的。歸納:使用超類的引用的任何上下文中也可以使用其子類的引用替代。這個原則極大的限制了在純擴展(繼承)機制里可以做的事情。不遵守會帶來風險。

  接口分離原則(ISP)

  一個類對另一個類的依賴應該限制在最小化的接口上。

  反向依賴原則(DIP)

  依賴抽象層(接口),而不是具體類。

  其它重要原則

  Demeter定律

  也被稱做封鎖信息原則:只跟朋友交流

  一個對象O的任何一個方法M只能調用下列類型的對象的方法:

  • 它自己
  • 它的參量
  • 它創建/實例化的對象
  • 它的直接組件對象

  參考

  好萊塢原則

  不要調用我,我會調用你的。

  不要自我重復(DRY)

  去掉重復代碼。

  對接口編程,而不是對實現

  反向依賴的另外一種說法。

  你不需要它(YAGNI)

  不要添加你“認為以后可能有用”的代碼。只在“事到臨頭”時才添加代碼。

  簡單化,傻瓜化(KISS)

  讓它能工作的最簡單的方法是什么?

4
0
 
 
 

文章列表

arrow
arrow
    全站熱搜
    創作者介紹
    創作者 大師兄 的頭像
    大師兄

    IT工程師數位筆記本

    大師兄 發表在 痞客邦 留言(0) 人氣()