色尼玛亚洲综合影院,亚洲3atv精品一区二区三区,麻豆freexxxx性91精品,欧美在线91

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

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

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

  好了,回歸主題。編程人生中,《編程人生》中至少有兩個人談到了設(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),我今天想拿籃球運(yùn)動做個對比。

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

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

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

  其實,上面的這些分析對于武術(shù)也同樣適用。武俠迷可能會記得金庸筆下紛繁復(fù)雜招式名稱(其實也是模式)。不過,金庸倒也提到過更高的境界:“無招勝有招”。印象當(dāng)中張無忌學(xué)習(xí)太極拳和令狐沖學(xué)習(xí)獨(dú)孤九劍有描述。他們在學(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)系我們修改或刪除,多謝。

主站蜘蛛池模板: 阿图什市| 安泽县| 南平市| 德化县| 通河县| 桂林市| 东源县| 安仁县| 甘孜县| 巴中市| 丰城市| 嘉峪关市| 仙居县| 远安县| 肇东市| 句容市| 连州市| 苍山县| 林芝县| 丘北县| 漳平市| 喀喇沁旗| 阿拉善右旗| 阳朔县| 嘉义市| 会东县| 郧西县| 普陀区| 德阳市| 县级市| 油尖旺区| 九龙县| 宁城县| 武城县| 湾仔区| 珲春市| 广丰县| 云和县| 建德市| 隆回县| 永宁县|