精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

一些軟件設(shè)計的原則

開發(fā) 架構(gòu)
這些原則,每一個程序員都應(yīng)該了解。但是請不要教條主義,在使用的時候還是要多多考慮實際情況。其實,下面這些原則,不單單只是軟件開發(fā),可以推廣到其它生產(chǎn)活動中,甚至我們的生活中。

以前本站向大家介紹過一些軟件開發(fā)的原則,比如優(yōu)質(zhì)代碼的十誡Unix傳奇(下篇)中所以說的UNIX的設(shè)計原則。相信大家從中能夠從中學(xué)了解到一些設(shè)計原理方面的知識,正如我在《再談“我是怎么招聘程序”》中所說的,一個好的程序員通常由其操作技能、知識水平,經(jīng)驗層力和能力四個方面組成。在這里想和大家說說設(shè)計中的一些原則,我認為這些東西屬于長期經(jīng)驗總結(jié)出來的知識。這些原則,每一個程序員都應(yīng)該了解。但是請不要教條主義,在使用的時候還是要多多考慮實際情況。其實,下面這些原則,不單單只是軟件開發(fā),可以推廣到其它生產(chǎn)活動中,甚至我們的生活中。

Don’t Repeat Yourself (DRY)

DRY 是一個最簡單的法則,也是最容易被理解的。但它也可能是最難被應(yīng)用的(因為要做到這樣,我們需要在泛型設(shè)計上做相當(dāng)?shù)呐Γ@并不是一件容易的事)。它意味著,當(dāng)我們在兩個或多個地方的時候發(fā)現(xiàn)一些相似的代碼的時候,我們需要把他們的共性抽象出來形一個唯一的新方法,并且改變現(xiàn)有的地方的代碼讓他們以一些合適的參數(shù)調(diào)用這個新的方法。

參考:http://en.wikipedia.org/wiki/Don%27t_repeat_yourself

Keep It Simple, Stupid (KISS)

KISS原則在設(shè)計上可能最被推崇的,在家裝設(shè)計,界面設(shè)計 ,操作設(shè)計上,復(fù)雜的東西越來越被眾人所BS了,而簡單的東西越來越被人所認可,比如這些UI的設(shè)計和我們中國網(wǎng)頁(尤其是新浪的網(wǎng)頁)者是負面的例子。“宜家”(IKEA)簡約、效率的家居設(shè)計、生產(chǎn)思路;“微軟”(Microsoft)“所見即所得”的理念;“谷歌”(Google) 簡約、直接的商業(yè)風(fēng)格,無一例外的遵循了“kiss”原則,也正是“kiss”原則,成就了這些看似神奇的商業(yè)經(jīng)典。而蘋果公司的iPhone/iPad 將這個原則實踐到了極至。

 

把一個事情搞復(fù)雜是一件簡單的事,但要把一個復(fù)雜的事變簡單,這是一件復(fù)雜的事。

參考:http://en.wikipedia.org/wiki/KISS_principle

Program to an interface, not an implementation

這是設(shè)計模式中最根本的哲學(xué),注重接口,而不是實現(xiàn),依賴接口,而不是實現(xiàn)。接口是抽象是穩(wěn)定的,實現(xiàn)則是多種多樣的。以后面我們會面向?qū)ο蟮腟OLID原則中會提到我們的依賴倒置原則,就是這個原則的的另一種樣子。還有一條原則叫 Composition over inheritance(喜歡組合而不是繼承),這兩條是那23個經(jīng)典設(shè)計模式中的設(shè)計原則。

Command-Query Separation (CQS)  – 命令-查詢分離原則

  • 查詢:當(dāng)一個方法返回一個值來回應(yīng)一個問題的時候,它就具有查詢的性質(zhì);
  • 命令:當(dāng)一個方法要改變對象的狀態(tài)的時候,它就具有命令的性質(zhì);

通常,一個方法可能是純的Command模式或者是純的Query模式,或者是兩者的混合體。在設(shè)計接口時,如果可能,應(yīng)該盡量使接口單一化,保證方法的行為嚴格的是命令或者是查詢,這樣查詢方法不會改變對象的狀態(tài),沒有副作用,而會改變對象的狀態(tài)的方法不可能有返回值。也就是說:如果我們要問一個問題,那么就不應(yīng)該影響到它的答案。實際應(yīng)用,要視具體情況而定,語義的清晰性和使用的簡單性之間需要權(quán)衡。將Command和Query功能合并入一個方法,方便了客戶的使用,但是,降低了清晰性,而且,可能不便于基于斷言的程序設(shè)計并且需要一個變量來保存查詢結(jié)果。

在系統(tǒng)設(shè)計中,很多系統(tǒng)也是以這樣原則設(shè)計的,查詢的功能和命令功能的系統(tǒng)分離,這樣有則于系統(tǒng)性能,也有利于系統(tǒng)的安全性。

參考:http://en.wikipedia.org/wiki/Command-query_separation

You Ain’t Gonna Need It (YAGNI)

這個原則簡而言之為——只考慮和設(shè)計必須的功能,避免過度設(shè)計。只實現(xiàn)目前需要的功能,在以后您需要更多功能時,可以再進行添加。

  • 如無必要,勿增復(fù)雜性。
  • 軟件開發(fā)先是一場溝通博弈。

以前本站有一篇關(guān)于過度重構(gòu)的文章,這個示例就是這個原則的反例。而,WebSphere的設(shè)計者就表示過他過度設(shè)計了這個產(chǎn)品。我們的程序員或是架構(gòu)師在設(shè)計系統(tǒng)的時候,會考慮很多擴展性的東西,導(dǎo)致在架構(gòu)與設(shè)計方面使用了大量折衷,***導(dǎo)致項目失敗。這是個令人感到諷刺的教訓(xùn),因為本來希望盡可能延長項目的生命周期,結(jié)果反而縮短了生命周期。

參考:http://en.wikipedia.org/wiki/You_Ain%27t_Gonna_Need_It

Law of Demeter – 迪米特法則

迪米特法則(Law of Demeter),又稱“最少知識原則”(Principle of Least Knowledge),其來源于1987年荷蘭大學(xué)的一個叫做Demeter的項目。Craig Larman把Law of Demeter又稱作“不要和陌生人說話”。在《程序員修煉之道》中講LoD的那一章叫作“解耦合與迪米特法則”。關(guān)于迪米特法則有一些很形象的比喻:

  • 如果你想讓你的狗跑的話,你會對狗狗說還是對四條狗腿說?
  • 如果你去店里買東西,你會把錢交給店員,還是會把錢包交給店員讓他自己拿?

和狗的四肢說話?讓店員自己從錢包里拿錢?這聽起來有點荒唐,不過在我們的代碼里這幾乎是見怪不怪的事情了。

對于LoD,正式的表述如下:

對于對象 ‘O’ 中一個方法’M',M應(yīng)該只能夠訪問以下對象中的方法:

  1. 對象O;
  2. 與O直接相關(guān)的Component Object;
  3. 由方法M創(chuàng)建或者實例化的對象;
  4. 作為方法M的參數(shù)的對象。

在《Clean Code》一書中,有一段Apache framework中的一段違反了LoD的代碼:

final String outputDir = ctxt.getOptions().getScratchDir().getAbsolutePath();

這么長的一串對其它對象的細節(jié),以及細節(jié)的細節(jié),細節(jié)的細節(jié)的細節(jié)……的調(diào)用,增加了耦合,使得代碼結(jié)構(gòu)復(fù)雜、僵化,難以擴展和維護。

在《重構(gòu)》一書中的代碼的環(huán)味道中有一種叫做“Feature Envy”(依戀情結(jié)),形象的描述了一種違反了LoC的情況。Feature Envy就是說一個對象對其它對象的內(nèi)容更有興趣,也就是說老是羨慕別的對象的成員、結(jié)構(gòu)或者功能,大老遠的調(diào)用人家的東西。這樣的結(jié)構(gòu)顯然是不合理的。我們的程序應(yīng)該寫得比較“害羞”。不能像前面例子中的那個不把自己當(dāng)外人的店員一樣,拿過客人的錢包自己把錢拿出來。“害羞”的程序只和自己最近的朋友交談。這種情況下應(yīng)該調(diào)整程序的結(jié)構(gòu),讓那個對象自己擁有它羨慕的feature,或者使用合理的設(shè)計模式(例如Facade和Mediator)。

參考:http://en.wikipedia.org/wiki/Principle_of_Least_Knowledge

面向?qū)ο蟮腟.O.L.I.D 原則

一般來說這是面向?qū)ο蟮奈宕笤O(shè)計原則,但是,我覺得這些原則可適用于所有的軟件開發(fā)。

Single Responsibility Principle (SRP) – 職責(zé)單一原則

關(guān)于單一職責(zé)原則,其核心的思想是:一個類,只做一件事,并把這件事做好,其只有一個引起它變化的原因。單一職責(zé)原則可以看作是低耦合、高內(nèi)聚在面向?qū)ο笤瓌t上的引申,將職責(zé)定義為引起變化的原因,以提高內(nèi)聚性來減少引起變化的原因。職責(zé)過多,可能引起它變化的原因就越多,這將導(dǎo)致職責(zé)依賴,相互之間就產(chǎn)生影響,從而極大的損傷其內(nèi)聚性和耦合度。單一職責(zé),通常意味著單一的功能,因此不要為一個模塊實現(xiàn)過多的功能點,以保證實體只有一個引起它變化的原因。

  • Unix/Linux是這一原則的***體現(xiàn)者。各個程序都獨立負責(zé)一個單一的事。
  • Windows是這一原則的反面示例。幾乎所有的程序都交織耦合在一起。

Open/Closed Principle (OCP) – 開閉原則

關(guān)于開發(fā)封閉原則,其核心的思想是:模塊是可擴展的,而不可修改的。也就是說,對擴展是開放的,而對修改是封閉的。

  • 對擴展開放,意味著有新的需求或變化時,可以對現(xiàn)有代碼進行擴展,以適應(yīng)新的情況。
  • 對修改封閉,意味著類一旦設(shè)計完成,就可以獨立完成其工作,而不要對類進行任何修改。

對于面向?qū)ο髞碚f,需要你依賴抽象,而不是實現(xiàn),23個經(jīng)典設(shè)計模式中的“策略模式”就是這個實現(xiàn)。對于非面向?qū)ο缶幊蹋恍〢PI需要你傳入一個你可以擴展的函數(shù),比如我們的C 語言的qsort()允許你提供一個“比較器”,STL中的容器類的內(nèi)存分配,ACE中的多線程的各種鎖。對于軟件方面,瀏覽器的各種插件屬于這個原則的實踐。

Liskov substitution principle (LSP) – 里氏代換原則

軟件工程大師Robert C. Martin把里氏代換原則最終簡化為一句話:“Subtypes must be substitutable for their base types”。也就是,子類必須能夠替換成它們的基類。即:子類應(yīng)該可以替換任何基類能夠出現(xiàn)的地方,并且經(jīng)過替換以后,代碼還能正常工作。另外,不應(yīng)該在代碼中出現(xiàn)if/else之類對子類類型進行判斷的條件。里氏替換原則LSP是使代碼符合開閉原則的一個重要保證。正是由于子類型的可替換性才使得父類型的模塊在無需修改的情況下就可以擴展。

這么說來,似乎有點教條化,我非常建議大家看看這個原則個兩個最經(jīng)典的案例——“正方形不是長方形”和“鴕鳥不是鳥”。通過這兩個案例,你會明白《墨子 小取》中說的 ——“娣,美人也,愛娣,非愛美人也….盜,人也;惡盜,非惡人也。”——妹妹雖然是美人,但喜歡妹妹并不代表喜歡美人。盜賊是人,但討厭盜賊也并不代表就討厭人類。這個原則讓你考慮的不是語義上對象的間的關(guān)系,而是實際需求的環(huán)境。

在很多情況下,在設(shè)計初期我們類之間的關(guān)系不是很明確,LSP則給了我們一個判斷和設(shè)計類之間關(guān)系的基準(zhǔn):需不需要繼承,以及怎樣設(shè)計繼承關(guān)系。

Interface Segregation Principle (ISP) – 接口隔離原則

接口隔離原則意思是把功能實現(xiàn)在接口中,而不是類中,使用多個專門的接口比使用單一的總接口要好。

舉個例子,我們對電腦有不同的使用方式,比如:寫作,通訊,看電影,打游戲,上網(wǎng),編程,計算,數(shù)據(jù)等,如果我們把這些功能都聲明在電腦的抽類里面,那么,我們的上網(wǎng)本,PC機,服務(wù)器,筆記本的實現(xiàn)類都要實現(xiàn)所有的這些接口,這就顯得太復(fù)雜了。所以,我們可以把其這些功能接口隔離開來,比如:工作學(xué)習(xí)接口,編程開發(fā)接口,上網(wǎng)娛樂接口,計算和數(shù)據(jù)服務(wù)接口,這樣,我們的不同功能的電腦就可以有所選擇地繼承這些接口。

這個原則可以提升我們“搭積木式”的軟件開發(fā)。對于設(shè)計來說,Java中的各種Event Listener和Adapter,對于軟件開發(fā)來說,不同的用戶權(quán)限有不同的功能,不同的版本有不同的功能,都是這個原則的應(yīng)用。

Dependency Inversion Principle (DIP) – 依賴倒置原則

高層模塊不應(yīng)該依賴于低層模塊的實現(xiàn),而是依賴于高層抽象。

舉個例子,墻面的開關(guān)不應(yīng)該依賴于電燈的開關(guān)實現(xiàn),而是應(yīng)該依賴于一個抽象的開關(guān)的標(biāo)準(zhǔn)接口,這樣,當(dāng)我們擴展程序的時候,我們的開關(guān)同樣可以控制其它不同的燈,甚至不同的電器。也就是說,電燈和其它電器繼承并實現(xiàn)我們的標(biāo)準(zhǔn)開關(guān)接口,而我們的開關(guān)產(chǎn)商就可不需要關(guān)于其要控制什么樣的設(shè)備,只需要關(guān)心那個標(biāo)準(zhǔn)的開關(guān)標(biāo)準(zhǔn)。這就是依賴倒置原則。

這就好像瀏覽器并不依賴于后面的web服務(wù)器,其只依賴于HTTP協(xié)議。這個原則實在是太重要了,社會的分工化,標(biāo)準(zhǔn)化都是這個設(shè)計原則的體現(xiàn)。

參考:http://en.wikipedia.org/wiki/Solid_(object-oriented_design)

Common Closure Principle(CCP)– 共同封閉原則

一個包中所有的類應(yīng)該對同一種類型的變化關(guān)閉。一個變化影響一個包,便影響了包中所有的類。一個更簡短的說法是:一起修改的類,應(yīng)該組合在一起(同一個包里)。如果必須修改應(yīng)用程序里的代碼,我們希望所有的修改都發(fā)生在一個包里(修改關(guān)閉),而不是遍布在很多包里。CCP原則就是把因為某個同樣的原因而需要修改的所有類組合進一個包里。如果2個類從物理上或者從概念上聯(lián)系得非常緊密,它們通常一起發(fā)生改變,那么它們應(yīng)該屬于同一個包。

CCP延伸了開閉原則(OCP)的“關(guān)閉”概念,當(dāng)因為某個原因需要修改時,把需要修改的范圍限制在一個最小范圍內(nèi)的包里。

參考:http://c2.com/cgi/wiki?CommonClosurePrinciple

Common Reuse Principle (CRP) – 共同重用原則

包的所有類被一起重用。如果你重用了其中的一個類,就重用全部。換個說法是,沒有被一起重用的類不應(yīng)該被組合在一起。CRP原則幫助我們決定哪些類應(yīng)該被放到同一個包里。依賴一個包就是依賴這個包所包含的一切。當(dāng)一個包發(fā)生了改變,并發(fā)布新的版本,使用這個包的所有用戶都必須在新的包環(huán)境下驗證他們的工作,即使被他們使用的部分沒有發(fā)生任何改變。因為如果包中包含有未被使用的類,即使用戶不關(guān)心該類是否改變,但用戶還是不得不升級該包并對原來的功能加以重新測試。

CCP則讓系統(tǒng)的維護者受益。CCP讓包盡可能大(CCP原則加入功能相關(guān)的類),CRP則讓包盡可能小(CRP原則剔除不使用的類)。它們的出發(fā)點不一樣,但不相互沖突。

參考:http://c2.com/cgi/wiki?CommonReusePrinciple

Hollywood Principle – 好萊塢原則

好萊塢原則就是一句話——“don’t call us, we’ll call you.”。意思是,好萊塢的經(jīng)紀(jì)人們不希望你去聯(lián)系他們,而是他們會在需要的時候來聯(lián)系你。也就是說,所有的組件都是被動的,所有的組件初始化和調(diào)用都由容器負責(zé)。組件處在一個容器當(dāng)中,由容器負責(zé)管理。

簡單的來講,就是由容器控制程序之間的關(guān)系,而非傳統(tǒng)實現(xiàn)中,由程序代碼直接操控。這也就是所謂“控制反轉(zhuǎn)”的概念所在:

  1. 不創(chuàng)建對象,而是描述創(chuàng)建對象的方式。
  2. 在代碼中,對象與服務(wù)沒有直接聯(lián)系,而是容器負責(zé)將這些聯(lián)系在一起。

控制權(quán)由應(yīng)用代碼中轉(zhuǎn)到了外部容器,控制權(quán)的轉(zhuǎn)移,是所謂反轉(zhuǎn)。

好萊塢原則就是IoC(Inversion of Control)或DI(Dependency Injection )的基礎(chǔ)原則。這個原則很像依賴倒置原則,依賴接口,而不是實例,但是這個原則要解決的是怎么把這個實例傳入調(diào)用類中?你可能把其聲明成成員,你可以通過構(gòu)造函數(shù),你可以通過函數(shù)參數(shù)。但是 IoC可以讓你通過配置文件,一個由Service Container 讀取的配置文件來產(chǎn)生實際配置的類。但是程序也有可能變得不易讀了,程序的性能也有可能還會下降。

參考:

High Cohesion & Low/Loose coupling & – 高內(nèi)聚,低耦合

這個原則是UNIX操作系統(tǒng)設(shè)計的經(jīng)典原則,把模塊間的耦合降到***,而努力讓一個模塊做到精益求精。

  • 內(nèi)聚:一個模塊內(nèi)各個元素彼此結(jié)合的緊密程度
  • 耦合:一個軟件結(jié)構(gòu)內(nèi)不同模塊之間互連程度的度量

內(nèi)聚意味著重用和獨立,耦合意味著多米諾效應(yīng)牽一發(fā)動全身。

參考:

Convention over Configuration(CoC)– 慣例優(yōu)于配置原則

簡單點說,就是將一些公認的配置方式和信息作為內(nèi)部缺省的規(guī)則來使用。例如,Hibernate的映射文件,如果約定字段名和類屬性一致的話,基本上就可以不要這個配置文件了。你的應(yīng)用只需要指定不convention的信息即可,從而減少了大量convention而又不得不花時間和精力啰里啰嗦的東東。配置文件很多時候相當(dāng)?shù)挠绊戦_發(fā)效率。

Rails 中很少有配置文件(但不是沒有,數(shù)據(jù)庫連接就是一個配置文件),Rails 的fans號稱期開發(fā)效率是 java 開發(fā)的 10 倍,估計就是這個原因。Maven也使用了CoC原則,當(dāng)你執(zhí)行mvn -compile命令的時候,不需要指源文件放在什么地方,而編譯以后的class文件放置在什么地方也沒有指定,這就是CoC原則。

參考:http://en.wikipedia.org/wiki/Convention_over_Configuration

Separation of Concerns (SoC) – 關(guān)注點分離

SoC 是計算機科學(xué)中最重要的努力目標(biāo)之一。這個原則,就是在軟件開發(fā)中,通過各種手段,將問題的各個關(guān)注點分開。如果一個問題能分解為獨立且較小的問題,就是相對較易解決的。問題太過于復(fù)雜,要解決問題需要關(guān)注的點太多,而程序員的能力是有限的,不能同時關(guān)注于問題的各個方面。正如程序員的記憶力相對于計算機知識來說那么有限一樣,程序員解決問題的能力相對于要解決的問題的復(fù)雜性也是一樣的非常有限。在我們分析問題的時候,如果我們把所有的東西混在一起討論,那么就只會有一個結(jié)果——亂。

我記得在上一家公司有一個項目,討論就討論了1年多,項目本來不復(fù)雜,但是沒有使用SoC,全部的東西混為一談,再加上一堆程序員注入了各種不同的觀點和想法,整個項目一下子就失控了。***,本來一個1年的項目做了3年。

實現(xiàn)關(guān)注點分離的方法主要有兩種,一種是標(biāo)準(zhǔn)化,另一種是抽象與包裝。標(biāo)準(zhǔn)化就是制定一套標(biāo)準(zhǔn),讓使用者都遵守它,將人們的行為統(tǒng)一起來,這樣使用標(biāo)準(zhǔn)的人就不用擔(dān)心別人會有很多種不同的實現(xiàn),使自己的程序不能和別人的配合。Java EE就是一個標(biāo)準(zhǔn)的大集合。每個開發(fā)者只需要關(guān)注于標(biāo)準(zhǔn)本身和他所在做的事情就行了。就像是開發(fā)鏍絲釘?shù)娜酥粚W⒂陂_發(fā)鏍絲釘就行了,而不用關(guān)注鏍帽是怎么生產(chǎn)的,反正鏍帽和鏍絲釘按標(biāo)來就一定能合得上。不斷地把程序的某些部分抽像差包裝起來,也是實現(xiàn)關(guān)注點分離的好方法。一旦一個函數(shù)被抽像出來并實現(xiàn)了,那么使用函數(shù)的人就不用關(guān)心這個函數(shù)是如何實現(xiàn)的,同樣的,一旦一個類被抽像并實現(xiàn)了,類的使用者也不用再關(guān)注于這個類的內(nèi)部是如何實現(xiàn)的。諸如組件,分層,面向服務(wù),等等這些概念都是在不同的層次上做抽像和包裝,以使得使用者不用關(guān)心它的內(nèi)部實現(xiàn)細節(jié)。

說白了還是“高內(nèi)聚,低耦合”。

參考:http://sulong.me/archives/99

Design by Contract (DbC) – 契約式設(shè)計

DbC的核心思想是對軟件系統(tǒng)中的元素之間相互合作以及“責(zé)任”與“義務(wù)”的比喻。這種比喻從商業(yè)活動中“客戶”與“供應(yīng)商”達成“契約”而得來。例如:

  • 供應(yīng)商必須提供某種產(chǎn)品(責(zé)任),并且他有權(quán)期望客戶已經(jīng)付款(權(quán)利)。
  • 客戶必須付款(責(zé)任),并且有權(quán)得到產(chǎn)品(權(quán)利)。
  • 契約雙方必須履行那些對所有契約都有效的責(zé)任,如法律和規(guī)定等。

同樣的,如果在程序設(shè)計中一個模塊提供了某種功能,那么它要:

  • 期望所有調(diào)用它的客戶模塊都保證一定的進入條件:這就是模塊的先驗條件(客戶的義務(wù)和供應(yīng)商的權(quán)利,這樣它就不用去處理不滿足先驗條件的情況)。
  • 保證退出時給出特定的屬性:這就是模塊的后驗條件——(供應(yīng)商的義務(wù),顯然也是客戶的權(quán)利)。
  • 在進入時假定,并在退出時保持一些特定的屬性:不變式。

契約就是這些權(quán)利和義務(wù)的正式形式。我們可以用“三個問題”來總結(jié)DbC,并且作為設(shè)計者要經(jīng)常問:

  • 它期望的是什么?
  • 它要保證的是什么?
  • 它要保持的是什么?

根據(jù)Bertrand Meyer氏提出的DBC概念的描述,對于類的一個方法,都有一個前提條件以及一個后續(xù)條件,前提條件說明方法接受什么樣的參數(shù)數(shù)據(jù)等,只有前提條件得到滿足時,這個方法才能被調(diào)用;同時后續(xù)條件用來說明這個方法完成時的狀態(tài),如果一個方法的執(zhí)行會導(dǎo)致這個方法的后續(xù)條件不成立,那么這個方法也不應(yīng)該正常返回。

現(xiàn)在把前提條件以及后續(xù)條件應(yīng)用到繼承子類中,子類方法應(yīng)該滿足:

  1. 前提條件不強于基類.
  2. 后續(xù)條件不弱于基類.

換句話說,通過基類的接口調(diào)用一個對象時,用戶只知道基類前提條件以及后續(xù)條件。因此繼承類不得要求用戶提供比基類方法要求的更強的前提條件,亦即,繼承類方法必須接受任何基類方法能接受的任何條件(參數(shù))。同樣,繼承類必須順從基類的所有后續(xù)條件,亦即,繼承類方法的行為和輸出不得違反由基類建立起來的任何約束,不能讓用戶對繼承類方法的輸出感到困惑。

這樣,我們就有了基于契約的LSP,基于契約的LSP是LSP的一種強化。

參考:http://en.wikipedia.org/wiki/Design_by_contract

Acyclic Dependencies Principle (ADP) – 無環(huán)依賴原則

包之間的依賴結(jié)構(gòu)必須是一個直接的無環(huán)圖形,也就是說,在依賴結(jié)構(gòu)中不允許出現(xiàn)環(huán)(循環(huán)依賴)。如果包的依賴形成了環(huán)狀結(jié)構(gòu),怎么樣打破這種循環(huán)依賴呢?有2種方法可以打破這種循環(huán)依賴關(guān)系:***種方法是創(chuàng)建新的包,如果A、B、C形成環(huán)路依賴,那么把這些共同類抽出來放在一個新的包D里。這樣就把 C依賴A變成了C依賴D以及A依賴D,從而打破了循環(huán)依賴關(guān)系。第二種方法是使用DIP(依賴倒置原則)和ISP(接口分隔原則)設(shè)計原則。

無環(huán)依賴原則(ADP)為我們解決包之間的關(guān)系耦合問題。在設(shè)計模塊時,不能有循環(huán)依賴。

參考:http://c2.com/cgi/wiki?AcyclicDependenciesPrinciple

————————————————————————————

上面這些原則可能有些學(xué)院派,也可能太為理論,我在這里說的也比較模糊和簡單,這里只是給大家一個概貌,如果想要了解更多的東西,大家可以多google一下。

不過這些原則看上去都不難,但是要用好卻并不那么容易。要能把這些原則用得好用得精,而不教條,我的經(jīng)驗如下:(我以為這是一個理論到應(yīng)用的過程)

  1. 你可以先粗淺或是表面地知道這些原則。
  2. 但不要急著馬上就使用。
  3. 在工作學(xué)習(xí)中觀察和總結(jié)別人或自己的設(shè)計。
  4. 再回過頭來了回顧一下這些原則,相信你會有一些自己的心得。
  5. 有適度地去實踐一下。
  6. Goto第 3步。

原文鏈接:一些軟件設(shè)計的原則

責(zé)任編輯:林師授 來源: 酷殼
相關(guān)推薦

2011-01-19 10:50:31

軟件設(shè)計師

2024-07-04 09:27:57

2023-11-29 07:51:40

嵌入式軟件設(shè)計

2011-07-13 09:13:56

Android設(shè)計

2011-07-13 10:12:56

SQL語句優(yōu)化操作符優(yōu)化

2022-12-27 09:56:34

架構(gòu)系統(tǒng)

2021-12-22 10:49:42

架構(gòu)運維技術(shù)

2009-09-27 11:09:42

API設(shè)計

2019-08-19 14:56:07

設(shè)計模式javascript

2011-08-01 10:37:29

軟件項目管理

2012-02-06 09:54:59

LibreOffice運營數(shù)據(jù)

2017-04-08 17:12:36

設(shè)計模式抽象策略模式

2011-09-19 10:15:10

移動界面設(shè)計

2017-08-28 15:00:20

軟件系統(tǒng)架構(gòu)風(fēng)格

2022-09-26 08:26:38

軟件定時器函數(shù)

2012-03-14 14:30:13

Ubuntu軟件包

2021-10-26 13:55:53

搞定系統(tǒng)設(shè)計

2017-08-30 17:59:20

Linux程序設(shè)計優(yōu)化措施

2011-12-05 10:12:35

網(wǎng)頁設(shè)計

2012-04-16 09:54:05

移動web錯誤理念
點贊
收藏

51CTO技術(shù)棧公眾號

日本不卡免费新一二三区| 国产精品麻豆欧美日韩ww| 久久久久久12| 日韩网站在线播放| 国产精品久久乐| 一区二区三区不卡视频| 久久久久久国产精品mv| 中文字幕欧美色图| 国产综合精品| 色综合一区二区三区| 日韩欧美亚洲精品| 国产jzjzjz丝袜老师水多| 亚洲国产专区校园欧美| 亚洲视频在线观看| 最好看的中文字幕| 亚洲深夜视频| 亚洲男人的天堂网| 欧美高清性xxxxhd| 亚洲a视频在线| 日韩精品午夜视频| 欧美激情一级二级| 欧美 日韩 国产 成人 在线观看| 欧美国产亚洲精品| 欧美中文字幕一区二区三区 | 亚洲午夜电影在线| 日韩精品另类天天更新| 亚洲av色香蕉一区二区三区| 日韩成人dvd| 午夜精品在线观看| 四虎影院中文字幕| 精品大片一区二区| 亚洲黄色在线观看| 下面一进一出好爽视频| 国产精品99| 欧美香蕉大胸在线视频观看| 亚洲天堂第一区| www亚洲人| 99久久精品99国产精品| 99精彩视频| 国产影视一区二区| 日本少妇一区二区| 日本精品久久久| 久久综合久久鬼| 亚洲欧美色图| 精品国内产的精品视频在线观看| a毛片毛片av永久免费| 国内视频在线精品| 精品国产一区二区三区不卡 | 制服诱惑一区| 国产福利片在线| 久久久不卡影院| 欧美精品一区二区视频| 涩爱av在线播放一区二区| 成人三级伦理片| 电影午夜精品一区二区三区| 国产熟女一区二区三区四区| 国内精品自线一区二区三区视频| 国产日韩欧美91| 中文字幕一区2区3区| 日韩激情视频在线观看| 日韩免费av一区二区| 日本中文字幕第一页| 国产精品永久| 日韩免费观看在线观看| 精品久久久久久久久久久久久久久久| 国产亚洲精品自拍| 日韩av观看网址| 无码一区二区三区| 久久99精品一区二区三区三区| 国产日韩视频在线观看| 国产三级三级在线观看| 国产很黄免费观看久久| 成人性生交大片免费看小说| 国产福利视频导航| 成人美女视频在线看| 国产伦精品一区二区三区四区视频 | 大乳在线免费观看| 国产精品少妇自拍| 精品一区二区成人免费视频| 日本高清在线观看| 亚洲成av人在线观看| 日日橹狠狠爱欧美超碰| 韩国主播福利视频一区二区三区| 91福利资源站| 污污视频网站在线| 91麻豆精品国产91久久久久推荐资源| 亚洲电影免费观看高清完整版在线观看 | 亚洲a∨精品一区二区三区导航| 日本国产一区二区| 中文国产在线观看| 欧美网色网址| 中文字幕亚洲欧美日韩高清| 欧美三级免费看| av不卡在线| 国产精品网红直播| 殴美一级特黄aaaaaa| 久久色成人在线| 三年中文高清在线观看第6集 | 亚洲精品精品亚洲| 国产性xxxx18免费观看视频| 在线日韩三级| 亚洲激情视频网站| 亚洲AV成人无码精电影在线| 亚洲激情二区| 国产玖玖精品视频| 黄色成人一级片| 亚洲国产精品二十页| 精品免费久久久久久久| 姬川优奈av一区二区在线电影| 91精品在线一区二区| 插吧插吧综合网| 中文字幕人成人乱码| 国产成人精品一区二区三区| 国产手机视频在线| 国产欧美日韩激情| 福利视频一区二区三区四区| 成人免费毛片嘿嘿连载视频…| 日韩视频一区二区| 福利视频第一页| 亚洲一区二区三区四区五区午夜| 91色精品视频在线| 国产最新视频在线| 亚洲444eee在线观看| 国产aaa一级片| 亚洲精品v亚洲精品v日韩精品| 一本一本久久a久久精品牛牛影视 一本色道久久综合亚洲精品小说 一本色道久久综合狠狠躁篇怎么玩 | 亚洲综合在线免费观看| 色婷婷成人在线| 午夜先锋成人动漫在线| 欧美激情综合亚洲一二区| 一级片一区二区三区| 久久久噜噜噜久久人人看| 99热久久这里只有精品| 成人国产精品久久| 中文字幕亚洲欧美| 欧美国产一级片| 99r精品视频| 17c丨国产丨精品视频| 中文成人在线| 日韩中文字幕在线视频播放| 日本免费精品视频| 国产亚洲一区二区三区四区| 久久国产精品视频在线观看| 999久久精品| 欧美俄罗斯乱妇| 国产富婆一级全黄大片| 亚洲欧美激情一区二区| 91精品999| 日韩成人精品一区| 国产女精品视频网站免费| 黄色视屏网站在线免费观看| 一本大道久久a久久精品综合| 免费不卡的av| 最新成人av网站| 国产一区二区无遮挡| av免费不卡| 亚洲精品乱码久久久久久金桔影视| 国产在线观看成人| 不卡电影免费在线播放一区| 精品少妇在线视频| 精品国产18久久久久久洗澡| 97久久超碰福利国产精品…| 亚洲欧美日韩综合在线| 色综合色狠狠天天综合色| aaaaaav| 免播放器亚洲| 色一情一乱一伦一区二区三欧美 | 欧美日韩亚洲国产一区| 91精品国产自产| 老色鬼久久亚洲一区二区| 欧美极品jizzhd欧美| 亚洲成人激情社区| 这里只有精品视频| 国产男女猛烈无遮挡| 一区二区三区在线播放| 亚州av综合色区无码一区| 午夜亚洲激情| 国产精品入口66mio| 国产精欧美一区二区三区| 尤物视频在线免费观看| 91精品国产色综合久久 | 亚洲一区二区欧美激情| 人妖粗暴刺激videos呻吟| 欧美亚洲三级| 五月天色婷婷综合| 久久免费视频66| 国产成人久久久精品一区| 免费在线观看黄色网| 欧美成人a∨高清免费观看| 日韩久久久久久久久| 国产亚洲精品7777| 97精品国产97久久久久久春色| 中文字幕 欧美日韩| 激情综合中文娱乐网| 蜜桃传媒视频麻豆一区| 午夜精品久久久久久毛片| 欧美国产日韩xxxxx| 男人天堂资源在线| 日韩一区二区三区免费看 | 午夜久久久久久久久| 中文字幕一区二区三区人妻| 美女视频黄a大片欧美| 成年人深夜视频| 久久99免费视频| 亚洲自拍欧美色图| 在线一区av| 毛片精品免费在线观看| 国产在线中文字幕| 亚洲精品一区二区三区在线观看| 国产99免费视频| 亚洲午夜精品网| 东京热无码av男人的天堂| 成人永久免费视频| 亚洲综合婷婷久久| 国产农村妇女精品一二区| 蜜臀在线免费观看| 精品国产午夜| 精品无码久久久久久久动漫| 国产精品亚洲综合在线观看| 国产精品91在线| 国产不卡人人| 欧美成人在线免费视频| 9色在线视频网站| 日韩精品在线视频美女| 国产激情视频在线播放| 欧美日韩国产综合视频在线观看| 国产精品自拍99| 夜夜精品视频一区二区| 熟女少妇a性色生活片毛片| 久久久五月婷婷| 99久久人妻精品免费二区| 国产伦精品一区二区三区在线观看| 日本激情视频在线| 久久狠狠婷婷| 成年人视频观看| 亚洲欧洲另类| 337p亚洲精品色噜噜狠狠p| 亚洲电影影音先锋| 亚洲一区二区三区四区中文| 精品久久成人| 日韩av一级大片| 欧美激情在线免费| 久久久久se| 欧美久久精品| 国产一区二区高清不卡| 日韩视频一二区| 91超碰在线电影| 996久久国产精品线观看| 国产97免费视| 在线一区av| 国产999精品久久久| www.综合| 97视频免费观看| 九色porny自拍视频在线观看 | 人人爽香蕉精品| 欧美一级黄色影院| 日日嗨av一区二区三区四区| 最近免费中文字幕中文高清百度| 亚洲欧美成人| 波多野结衣作品集| 日本欧美一区二区在线观看| 天天操天天爱天天爽| 丝袜美腿亚洲一区| 91国产精品视频在线观看| 麻豆精品视频在线观看视频| 国产资源在线视频| 噜噜噜躁狠狠躁狠狠精品视频| 欧美成人免费高清视频| 新67194成人永久网站| 黄色一级免费大片| 久久97超碰国产精品超碰| 黄色三级视频在线播放| 国产成人免费高清| 国产伦精品一区三区精东| 99久久婷婷国产综合精品| 亚洲 小说 欧美 激情 另类| 日本一区二区三区免费乱视频| 国产免费嫩草影院| 亚洲美女视频在线观看| 99免费在线观看| 在线观看一区二区精品视频| 国产精品伦理一区| 亚洲第一区第一页| 电影在线一区| 九九九久久久久久| 91久久国产综合久久91猫猫| 国产美女久久精品| 99a精品视频在线观看| 欧美日韩亚洲在线| 久久久久av| 精品少妇人妻av免费久久洗澡| 三级欧美韩日大片在线看| 日本黄色福利视频| 成人国产视频在线观看| 国产精品久久久久无码av色戒| 国产精品电影院| 国产精品不卡av| 欧美色大人视频| 隣の若妻さん波多野结衣| 国产亚洲人成a一在线v站| 羞羞视频在线观看免费| 欧美在线国产精品| 青青操视频在线| 日韩在线播放视频| 九色porny丨国产首页在线| 成人激情视频网| 日韩av影院| 黄色a级在线观看| 亚洲一区二区动漫| 欧美熟妇精品一区二区| 中文成人av在线| 国产九色在线播放九色| 日韩欧美久久一区| aaa在线观看| 日本sm极度另类视频| 欧美日韩午夜电影网| 色噜噜狠狠色综合网| 国产日韩欧美三区| 日批视频在线看| 国产精品久久夜| 五月婷婷激情视频| 精品99999| 最新黄网在线观看| 国产美女91呻吟求| 久操成人av| 国产中文字幕二区| 国产美女视频一区| 女同久久另类69精品国产| 狠狠爱在线视频一区| 午夜精品久久久久久久爽| 色哟哟网站入口亚洲精品| 无遮挡爽大片在线观看视频| 成人精品水蜜桃| 亚洲午夜精品一区二区国产| 欧美一级黄色影院| 久久久久国产精品人| www日韩精品| 精品国产sm最大网站| 午夜成年人在线免费视频| 成人午夜激情免费视频| 久久中文字幕av| 成人免费视频久久| 久久久精品国产免大香伊| 欧美一区二区激情视频| 亚洲精品国产欧美| 99在线视频影院| 国产精品一区而去| 精品69视频一区二区三区Q| 欧美一级大片免费看| 亚洲欧美日韩国产一区二区三区| 中文字幕在线网站| 最新的欧美黄色| 欧美高清影院| 国产精品美女在线播放| 美女视频免费一区| 四虎影视一区二区| 在线播放中文一区| 菠萝菠萝蜜在线观看| 91精品久久久久久蜜桃| 亚洲国产不卡| 中文字幕一区二区三区人妻在线视频 | 麻豆网站在线观看| 91久久国产精品91久久性色| 亚洲乱码精品| 野战少妇38p| 精品久久久久久久中文字幕| 欧洲免费在线视频| 国产精品美女www| 亚洲精品888| 亚洲图片欧美另类| 色妹子一区二区| 日本激情视频在线观看| 91在线观看网站| 亚洲精品婷婷| 91成人在线免费视频| 欧美喷水一区二区| 久久亚洲资源| 欧美日韩高清免费| 久久er精品视频| 国产一级淫片免费| 一色桃子一区二区| 中文字幕av一区二区三区四区| 激情深爱综合网| 国产欧美日韩激情| 精品国产18久久久久久| 孩xxxx性bbbb欧美| 国产欧美日韩免费观看| 99精品999| 黑人精品xxx一区一二区| 91精品国产综合久久久久久豆腐| 亚洲自拍小视频免费观看| 99国产精品久久久久久久成人热| 国产123在线| 日韩精品一区二区三区中文精品| 亚洲黄色免费看| 国产成人精品免费看在线播放| 99久免费精品视频在线观看| 亚洲天堂中文字幕在线| 97精品久久久| 一区二区在线影院|