中文字幕日韩一区二区_国产一区二区av_国产毛片av_久久久久国产一区_色婷婷电影_国产一区二区精品

觀點:如何正確的對待設(shè)計模式

  自從接觸設(shè)計模式以來,一般看到的評論是以推崇為多。不過比較欣慰的是,最近在看《編程人生》中,有兩個人對設(shè)計模式比較不屑。

  之所以欣慰,并不是因為湊個熱鬧看他們互相攻擊,互相批評——而是因為出現(xiàn)了不同的觀點,特別是兩位非常有分量的人物的觀點。在技術(shù)領(lǐng)域,眾口一詞是一件非??植赖氖虑?;百花齊放百家爭鳴才是我們樂于看到的。因為不同觀點的出現(xiàn),特別是大師級的不同觀點,能夠促進(jìn)更多的人去獨立的思考與探索。

  好了,回歸主題。編程人生中,《編程人生》中至少有兩個人談到了設(shè)計模式。

  Jamie Zawinski —— 著名的LISP黑客,NETscape瀏覽器和Mozilla瀏覽器的核心開發(fā)者。在談到程序員要讀的書時說:

  “還有一本書叫《設(shè)計模式》,人人追捧,奉為圭臬。不過,在我看來,這本書一派胡言,給人的感覺好像是編程只需要剪貼粘貼就能搞定。你不用全盤考慮要做的任務(wù),只要看看這本配方書,找個有幾分相近的模式,直接套用就行了。那根本不是編程,那是在涂色書。不過,似乎很多人都對這本書著了魔。”

  Brendan Eich —— JavaScript之父,Mozilla公司CTO,在提到為編程想做而沒有做的事情時說:

  “我并不是一個熱衷于面向?qū)ο蠛驮O(shè)計模式的人。從來沒有買過Gamma的書(《設(shè)計模式》)。網(wǎng)景公司有些人買,Jamie zawinski的人或者網(wǎng)景收購的公司來的那些冤家對頭會買,他們把這本書當(dāng)圣經(jīng)一樣顯擺,真有點讓人受不了,他們根本就不是最好的程序員。”

  至于什么是設(shè)計模式,他有什么好處等等,不是我今天要說。我想舉個例子,做個對比。我們都知道,設(shè)計模式源于建筑領(lǐng)域,建筑領(lǐng)域可能離我們太遠(yuǎn),我今天想拿籃球運動做個對比。

  籃球運動員為了提高籃球水平,除了進(jìn)行身體訓(xùn)練和投籃訓(xùn)練外,還會進(jìn)行一些連貫動作的訓(xùn)練和一些戰(zhàn)術(shù)配合訓(xùn)練。比如,像交叉步,急停跳投,轉(zhuǎn)身過人,擋拆等等。這些訓(xùn)練是從何而來?籃球運動剛剛誕生的時候肯定沒有。而是運動員在籃球運動過程中,發(fā)現(xiàn)在某一種情況下(也就是防守隊員和團(tuán)隊成員的位置),使用某一種類似的連貫動作往往能夠取到非常好的效果。所以就有悟性非常高的人把這種約束條件和要采取的動作都總結(jié)出來,讓運動員在訓(xùn)練中反復(fù)的訓(xùn)練,以形成一種條件反射,在出現(xiàn)合適的機(jī)會的時候,快速而有效的使用這些連貫動作。

  我想這也是模式的起源。有一點不同的是,我們學(xué)習(xí)設(shè)計模式的過程,是一種思維訓(xùn)練的過程

  不難想象,如果沒有這些東西,運動員要提高籃球水平有多困難。但運動員如果在比賽中濫用,花哨的動作也許會增強(qiáng)比賽的觀賞性,但是它卻偏離了籃球運動的本質(zhì):將籃球投進(jìn)并贏得比賽。

  其實,上面的這些分析對于武術(shù)也同樣適用。武俠迷可能會記得金庸筆下紛繁復(fù)雜招式名稱(其實也是模式)。不過,金庸倒也提到過更高的境界:“無招勝有招”。印象當(dāng)中張無忌學(xué)習(xí)太極拳和令狐沖學(xué)習(xí)獨孤九劍有描述。他們在學(xué)成之后確實很厲害。難怪Jamie Zawinski和Brendan Eich會有些反對模式,也許他們已經(jīng)學(xué)到了無招勝有招的真諦,也許他們是黑客,不喜歡思維受到限制。

  難道我們要拋棄所有的模式?不過我認(rèn)為它可能并不適合所有的人,它依賴于人的造詣,以及天賦,悟性。我們很多人要獲得提高,進(jìn)行一些模式訓(xùn)練,也許還是一條非常有效的途徑。

  亂七八糟說了這么多,最后總結(jié)一下:

  1. 首先要認(rèn)識到它的本質(zhì),模式是前人知識經(jīng)驗的總結(jié),不是現(xiàn)成的解決方案,所以不要硬套。
  2. 對于初學(xué)者來說,模式是個好東西,學(xué)習(xí)一些模式是一條有效的提高途徑。
  3. 不要過度使用設(shè)計模式,他會給你帶來額外的復(fù)雜度。在我的眼中,簡單性才是一個技術(shù)方案的首要因素。你知不知道李小龍截拳道的核心是什么?拋開招式,直截了當(dāng)?shù)倪M(jìn)行最有效的攻擊和防守。
  4. 不要把它當(dāng)成銀彈或者圣杯。
  5. 當(dāng)你有一定的積累后,你也可以嘗試“無招勝有招”的境界。

  PS:我看過的一個比較奇特的觀點,值得思考:

  《黑客與畫家》的作者在書中提到過,說有人做過研究,LISP語言自帶可以支持GOF(四人幫)總結(jié)的16中模式。所以,如果你在編程時需要用到模式,那可能是你的語言不夠強(qiáng)大,模式應(yīng)該是語言支持的東西。(這段話是我根據(jù)印象寫的,沒有找到原話,所以可能有些出入。)

it知識庫觀點:如何正確的對待設(shè)計模式,轉(zhuǎn)載需保留來源!

鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標(biāo)記有誤,請第一時間聯(lián)系我們修改或刪除,多謝。

主站蜘蛛池模板: 黄色一级特级片 | 91精品久久久久久久久 | 91色在线视频 | 国产视频在线一区二区 | 成人综合伊人 | 亚洲精品在线观看视频 | 精品欧美乱码久久久久久 | 99精品国产成人一区二区 | 日韩成人在线视频 | 一二三四在线视频观看社区 | www国产亚洲精品 | av毛片免费 | 日本久久久一区二区三区 | 国产精品美女www | av在线三级 | 成人做爰www免费看视频网站 | 欧美视频一区二区三区 | 亚洲三级在线观看 | 久久国产精品一区二区三区 | 日韩成人在线电影 | 男女在线免费观看 | 亚洲一区二区免费视频 | 亚洲精品www久久久久久广东 | 国产伦精品一区二区三区照片91 | 国产97久久| 免费午夜视频在线观看 | 精品国产一区二区三区久久 | 午夜一区 | 日韩欧美在线视频播放 | 久久国产成人 | 久久88| 国产传媒 | 在线观看中文字幕视频 | 日韩精品一区二区三区中文在线 | 欧美精品一区二区在线观看 | 日本色高清 | 国产乱码精品1区2区3区 | 国产成人免费视频 | 网站黄色在线 | 日本一本视频 | 91精品久久久久久久久久入口 |