咨詢電話:023-6276-4481
熱門文章
電 話:023-6276-4481
郵箱:broiling@qq.com
地址:重慶市南岸區(qū)亞太商谷6幢25-2
很多人應該聽說過設計模式(Design pattern),又或多或少的看過或用過設計模式,但是實際用在開發(fā)過程中總有點心有余而力不足的感覺。那肯定是對設計模式的理解有少許偏差或者不夠深入。先不談某種具體的模式,先來看看什么是設計模式?
設計模式是一套代碼設計「經(jīng)驗的總結」。項目中「合理的」運用設計模式可以「巧妙的解決很多問題」。
經(jīng)驗的總結:抱著「代碼虐我千百遍,我待代碼如初戀」的心態(tài),最終得出來的「套路」。
合理的:要對設計模式的使用場景有一定的認識后才使用,「不要濫用」。如:輸出一句“hello world”,非要強行給加上各種模式。
問:“為什么”,答:“總感覺少了模式!”。
巧妙的解決了很多問題:被廣泛應用的原因。
為什么要提倡“Design Pattern呢?根本原因是為了代碼復用,增加可維護性。那么怎么才能實現(xiàn)代碼復用呢?
1988年,勃蘭特·梅耶(Bertrand Meyer)在他的著作《面向對象軟件構造(Object Oriented Software Construction)》中提出了開閉原則,它的原文是這樣:“Software entities should be open for extension,but closed for modification”。
意思:軟件模塊應該對擴展開放,對修改關閉。
舉例:在程序需要進行新增功能的時候,不能去修改原有的代碼,而是新增代碼,實現(xiàn)一個熱插拔的效果(熱插拔:靈活的去除或添加功能,不影響到原有的功能)。
目的:為了使程序的擴展性好,易于維護和升級。
意思:里氏代換原則是繼承復用的基石,只有當衍生類可以替換掉基類,軟件單位的功能不受到影響時,基類才能真正被復用,而衍生類也能夠在基類的基礎上增加新的行為。
舉例:球類,原本是一種體育用品,它的衍生類有籃球、足球、排球、羽毛球等等,如果衍生類替換了基類的原本方法,如把體育用品改成了食用品(那么軟件單位的功能受到影響),就不符合里氏代換原則。
目的:對實現(xiàn)抽象化的具體步驟的規(guī)范。
意思:針對接口編程,而不是針對實現(xiàn)編程。
舉例:以計算機系統(tǒng)為例,無論主板、CPU、內存、硬件都是在針對接口設計的,如果針對實現(xiàn)來設計,內存就要對應到針對某個品牌的主板,那么會出現(xiàn)換內存需要把主板也換掉的尷尬。
目的:降低模塊間的耦合。
使用多個隔離的接口,比使用單個接口要好。
舉例:比如:登錄,注冊時屬于用戶模塊的兩個接口,比寫成一個接口好。
目的:提高程序設計靈活性。
1987年秋天由美國Northeastern University的Ian Holland提出,被UML的創(chuàng)始者之一[Booch]等普及。后來,因為在經(jīng)典著作《 The Pragmatic Programmer》而廣為人知。
意思:一個實體應當盡量少的與其他實體之間發(fā)生相互作用,使得系統(tǒng)功能模塊相對獨立。
舉例:一個類公開的public屬性或方法越多,修改時涉及的面也就越大,變更引起的風險擴散也就越大。
目的:降低類之間的耦合,減少對其他類的依賴。
該原則由羅伯特·C·馬?。≧obert C. Martin)于《敏捷軟件開發(fā):原則、模式和實踐》一書中給出的。馬丁表示此原則是基于湯姆·狄馬克(Tom DeMarco)和Meilir Page-Jones的著作中的內聚性原則發(fā)展出的。
意思:一個類只負責一個功能領域中的相應職責,或者可以定義為:就一個類而言,應該只有一個引起它變化的原因。
舉例:該原則意思簡單到不需要舉例!
目的:類的復雜性降低,可讀性提高,可維護性提高。
剛入行的時候,在想什么樣的代碼是好代碼?看到很多前輩的文字都說好的代碼要符合「高內聚,低耦合」,但是我聽到這樣的解釋,是這樣的
而現(xiàn)在對設計模式有了一定程度上的學習,感覺懂了一些,小伙伴們你們學會了嗎?
內聚是從功能角度來度量模塊內的聯(lián)系,一個好的內聚模塊應當恰好做一件事。它描述的是模塊內的功能聯(lián)系;
耦合是軟件結構中各模塊之間相互連接的一種度量,耦合強弱取決于模塊間接口的復雜程度、進入或訪問一個模塊的點以及通過接口的數(shù)據(jù)。