1. 程式人生 > >寫了這麼多年程式碼,你真的瞭解設計模式麼?

寫了這麼多年程式碼,你真的瞭解設計模式麼?

昨天和同事聊到最近他要做的一個培訓,大概的課程是這樣的:

第一天:

  • 上午:面向物件原則(OO+SOLID )
  • 下午:設計模式(Design Pattern)

第二天:

  • 上午:簡單設計(SimpleDesign)
  • 下午:重構到模式(Refactor to DesignPattern)

面向物件原則,設計模式,簡單設計,重構到模式……看起來都是常規操作,但你有想過他們的關係麼?

上面提到的每一項大家都耳熟能詳,但我發現大部分開發者並沒有真正理解。要獲得最大收益,就必須理解它們之間的關係,並綜合應用所有這些原則。只有把它們作為一個整體,才可能構建出堅實(Solid)的軟體。遺憾的是,我們看到的書籍和文章都在羅列每個原則,沒有把它們作為一個整體來看,甚至提出這幾項的知名大叔們也沒能講透徹。因此我嘗試介紹一下我的理解。

面向物件原則(OO+SOLID )

簡單理解,面向物件原則給我們提供了一系列面向物件上下文下的最佳實踐,指導原則和終極目標,符合這些原則可以幫助我們最大化OO的威力。

如果把面向物件類比成軟體開發領域的一個武林門派,面向物件原則就是這個門派的最高心法和目標,打個比方,有點像:心與意合,意與氣合,氣與力合,肩與胯合,肘與膝合,手與足合……這種。

心法這種東西就是神神祕祕的,真正看起來也簡單,字面上也不難理解,很容易用它來挑戰別人:“你看你看,你沒有做到手與足合!”

但是回到自己,要想做到就難了,知易行難!

歸其原因它雖然提供了目標和評價標準,使我們很容易拿他來評價別人,但並沒有告訴我們自己如何才能達到這樣的目標和標準。

設計模式(Design Pattern)

那設計模式是什麼?

很多人,包括我在內,都曾迷陷於23種設計模式之中,初識設計模式,讚歎於其精妙,就像個萌新的江湖小生,偶然間掉到個山洞,一下就集齊了威震江湖的“7種武器”。

然後……就開始了用長生劍切菜,用碧玉刀削瓜的“幸福生活”,不但把簡單的事情搞得巨複雜,最不能忍的是還暴殄天物!

回到設計模式,無非是在面向物件原則這些虛無縹緲的“心法”指導原則下,那些前輩大神們留下的“招式”或是“套路”而已。但招式和套路並不能致勝,它只是為我們這等小白提供了一個接近大神,理解心法的途徑而已,通過長年累月的模仿去反思去領悟去體會“心法”的本質和精妙,此時腦中不禁浮現《少林寺》中李連杰夏練三九冬練三伏的畫面……

這就能解釋為什麼使用同樣的招式,大神們總能一擊致命,而我們卻總是被按倒在地摩擦的原因了。

簡單設計(SimpleDesign)

設計模式是套路和招式,那簡單設計是什麼?

首先要區分一下簡單設計和容易設計:

簡單的反義詞是複雜,容易的反義詞是困難。簡單不等於容易,追求簡單的過程往往很困難,如果只是追求容易的往往導致系統過於複雜。

這是好多年前一位同事提到過的一句話,很在點兒上,我們經常混淆了簡單和容易,對於這點,另一位同事之前也寫過一篇文章來闡述做到“簡單”的“困難”。

做為結果的簡單設計是這麼一種設計,它能被幾乎所有人理解, 但只有極少數人能做出. 或者反過來說也可以. 簡單設計是一種只有極少數人能做出的設計,但設計一旦做出後,能被所有人理解.

可見簡單設計是一種只有極少數人能做出的設計,那我們怎麼才能成為那“極少數人“呢?

對此,Kent Beck給出了清晰的答案:

  1. 通過所有測試(Passes its tests)
  2. 儘可能消除重複 (Minimizes duplication)
  3. 儘可能清晰表達 (Maximizes clarity)
  4. 更少程式碼元素 (Has fewer elements)
  5. 以上四個原則的重要程度依次降低。

這組定義被稱做簡單設計原則。

我們不具體探討這幾個原則,回到最初的問題,如果說面向物件原則是”心法“是”目標“,設計模式是前輩們沉澱下來的”套路”和“招式“的話,那簡單設計是什麼呢?

我覺得就是實戰指導原則,他可以讓我們不侷限於哪些經典的過往的招式,跳出套路,無招勝有招。

如果說設計模式是一種自上而下,通過不斷模仿前輩大神套路達到目標的一條道路的話(有招勝無招);那簡單設計原則則是另一條自下而上,忘掉招式和套路,遵循簡單的基本原則,隨機應變,不斷演進,不斷浮現,逐步逼近目標的另一條道路(無招勝有招)。

但,記住,殊途同歸。

好,這位客官問了,那兩條道路都可以幫我們掌握武功最高的心法的目標,我走哪條呢?如果我已經會了一條,還需要學習另一條路徑麼?

重構到模式(Refactor to DesignPattern)

說到這裡,就不難理解“重構到模式”到底在說什麼了吧。

它無非是在解釋如何通過自下而上應用簡單設計原則,運用重構的技術和手法,浮現出設計模式。我管這個過程叫“重走長征路”,重新體驗一下那些大神前輩們建立發現設計模式的過程。

這個過程也再次證明了這兩條通往同一個目標的不同的道路也是可以相互轉換的,它們只不過是面向物件原則下的兩種不同形式的表現而已。

如果說“設計模式”是“有招勝無招”,“簡單設計”是“無招勝有招”的話,那“重構到模式”就是“無招生有招”的過程。

總結

總的來說,我們可以把這幾個概念作為一個整體框架來思考。

“面向物件原則”是OO領域的終極目標,是面向物件這門武功的心法,很容易用來評判別人,但是自己卻很難達到。

為了能達到心法的境界,之前的各任掌門大神們總結並留下了一些套路和招式,什麼降龍十八掌之類的,讓我等晚輩可以通過日復一日的刻意練習,去不斷參透心法的真諦,這些套路和招式就是“設計模式”。

但只有這十八招顯然是不夠的,於是我們又學到了一些實戰指導原則,讓我們以另一種方式,自下而上,跳出招式和套路的限制,甚至能不斷浮現出新的招式,且通向的是同一個目標,這些實戰指導原則就是“簡單設計原則”。

最後,不斷操練“重構到模式”,通過實際運用實戰指導原則和手法,推演招式和套路,幫助我們將這兩種方法融會貫通,相互結合,最終領悟那隱藏在一切表象背後的真理,達到無招勝有招,草木竹石皆可為劍,心隨意走,人隨心動的境界。

文/ThoughtWorks王健 更多精彩洞見,請關注微信公眾號:思特沃克