摘要:拿足球比賽的例子來說,我們的目標只是進球,下底傳中這種模式僅僅是達到進球目標的一種手段。但在這種動態(tài)解釋型語言中,給對象動態(tài)添加職責(zé)是再簡單不過的事情。這就造成了語言的裝飾者模式不再關(guān)注于給對象動態(tài)添加職責(zé),而是關(guān)注于給函數(shù)動態(tài)添加職責(zé)。
非商業(yè)轉(zhuǎn)載請注明作譯者、出處,并保留本文的原始鏈接:http://www.ituring.com.cn/article/199456
曾探,2007年畢業(yè)于吉林大學(xué)軟件學(xué)院,目前就職于騰訊AlloyTeam前端團隊任高級工程師, 著有《JavaScript設(shè)計模式與開發(fā)實踐》一書。他曾參與WebQQ、QQ群、Q+開發(fā)者網(wǎng)站、微云、QQ興趣部落等大型項目的開發(fā)。有Java、Python和JavaScript的開發(fā)經(jīng)驗,業(yè)余作品有HTML5街頭霸王等。平時喜歡電影和音樂,業(yè)余時間是一名健身教練。
問:你是從什么時候開始編程的?什么樣的契機讓你成為了一名前端工程師?
我是07年大學(xué)畢業(yè)之后才開始編程。剛工作的時候做的是Java開發(fā),當時幾乎還沒有公司提供純粹的前端開發(fā)職位。如果做的是web項目,那么在項目中程序員的工作都是從前端到數(shù)據(jù)庫一鍋端。
剛接觸JavaScript的時候,覺得開發(fā)很方便,不需要搭建任何環(huán)境,新建一個記事本就可以開擼了。第一次接觸JavaScript時用2天時間寫了個貪食蛇,在IE6上跑的很歡快,當時覺得很神奇,也很開心。
我09年我開始專職做前端開發(fā),在之前的工作還是以Java為主,有次剛好看到了一家公司招聘前端開發(fā),就有了后來的事情。雖然現(xiàn)在偶爾還會用其他語言寫點東西,但自己本身最喜歡的語言還是JavaScript,這也是為什么我會從事前端開發(fā)的原因。
至于為什么我會喜歡JavaScript,而不是別的語言,我倒沒有認真從語法、語言歷史什么的角度去想過。也許就跟四月清晨遇到的百分百女孩一樣,總之你一眼就認定是她。
問:在學(xué)習(xí)設(shè)計模式的過程中是否遇到過困難?你是如何克服的?對于正在閱讀《設(shè)計模式》和《JavaScript設(shè)計模式與開發(fā)實踐》的讀者,你有什么建議?
有時候我在QQ群或者論壇之類的地方聽見一些新人說:“接下來1個月我要把設(shè)計模式學(xué)完。”其實設(shè)計模式這種東西很難用學(xué)完來作為衡量標準。
如果你剛成為程序員不久,其實是沒有必要刻意去學(xué)習(xí)設(shè)計模式的。如果沒有一定程度的積累,看設(shè)計模式那些東西跟背書的效果差不多,結(jié)果都是無根的浮萍。設(shè)計模式本身是從代碼中總結(jié)而來的一些設(shè)計技巧,如果沒有代碼量的積累,我們很難去真正理解這些模式。
在無數(shù)行代碼的積累之后,自然而然我們會發(fā)現(xiàn)已經(jīng)使用過一些模式,但缺少一些總結(jié),使用的方式和場景或許還有改進的余地。這時候再去看一看設(shè)計模式之類的書籍或者文章,才會有一種茅塞頓開的感覺。
《設(shè)計模式》這本書本身還是比較難懂的,這本書本身很薄,但字字珠璣,正因為如此,很多重要的知識和思想可能就在1、2句看似不起眼的話中。如果是閱讀這本書,建議精讀和反復(fù)讀。暫時看不懂也沒有關(guān)系,先放著過一段時間再來看,或者是工作中遇到了類似的問題,再來翻翻這本書。
相反的是,《JavaScript設(shè)計模式與開發(fā)實踐》這本書寫得非常簡單,從讀者的反饋來看,這也是一本容易閱讀的書。里面舉的例子并不復(fù)雜,而且大多都是跟實際開發(fā)相關(guān)的,所以閱讀起來也會有種親切感。這本書沒有特別的閱讀建議,從第一頁開始,或者從某一頁開始都可以。但最靠譜的,還是從前言開始。
問:如何正確地使用設(shè)計模式? 如何避免過度設(shè)計?
這個問題在《JavaScript設(shè)計模式與開發(fā)實踐》的前言部分已經(jīng)提到過。設(shè)計模式被一些人認為只是夸夸其談的東西,他們認為設(shè)計模式?jīng)]有太大的用途,畢竟一個完全沒有接觸過設(shè)計模式的程序員,也許亦經(jīng)歷過許多不錯的軟件系統(tǒng)開發(fā)。他們覺得刻意去使用設(shè)計模式反而可能會增加程序的復(fù)雜度。
對于開發(fā)中的一些情況來說,我們也許在一些特定的場景里,一眼就能看出來使用什么模式。另外一些模式則是在代碼重構(gòu)的時候才加上的。
我們不必去糾結(jié)一開始就應(yīng)該使用什么模式,在首先完成功能需求的前提下,如果使用某種模式會在將來的項目維護階段為我們帶來好處,則可以用這些模式來重構(gòu)代碼。如果以前的代碼就完成了需求,而且在維護階段不會帶來大的變化,那我們就沒有必要非得往模式上面套。
如果要避免在程序中造成過度設(shè)計,首先得熟悉這些模式的用途和場景。
有時候我們將一些模式用在了錯誤的場景中,或者說在不該使用模式的地方刻意使用模式。特別是初學(xué)者在剛學(xué)會使用一個模式時,恨不得把所有的代碼都用這個模式來實現(xiàn)。錘子理論在這里體現(xiàn)得很明顯:當我們有了一把錘子,看什么都是釘子。拿足球比賽的例子來說,我們的目標只是進球,“下底傳中”這種“模式”僅僅是達到進球目標的一種手段。當我們面臨密集防守時,下底傳中或許是一種好的選擇;但如果我們的球員獲得了一個直接面對對方守門員的單刀機會,那么是否還要把球先傳向邊路隊友,再由邊路隊友來一個邊路傳中呢?答案是顯而易見的,模式應(yīng)該用在正確的地方。而哪些才算正確的地方,只有在我們深刻理解了模式的意圖之后,再結(jié)合項目的實際場景才會知道。
問:JavaScript設(shè)計模式和其他語言設(shè)計模式的主要區(qū)別是什么?
關(guān)于設(shè)計模式的大多數(shù)討論都是源自C++,Java這些靜態(tài)類型語言,而JavaScript是一門動態(tài)類型語言。許多設(shè)計模式就是為了解開對象之間的類型耦合而生的,而作為動態(tài)類型語言的JavaScript沒有這種困擾,這說明JavaScript語言中的設(shè)計模式和其他語言是非常不同的,從結(jié)構(gòu)上已經(jīng)沒有什么可借鑒的東西了,能夠借鑒的只有思想和解決問題的場景。
人類飛上天空需要借助飛機等工具,而鳥兒天生就有翅膀。在Dota游戲里,牛頭人的人生目標是買一把跳刀(跳刀可以使用跳躍技能),而敵法師天生就有跳躍技能。因為語言的不同,一些設(shè)計模式在另外一些語言中的實現(xiàn)也許跟我們在《設(shè)計模式》一書中看到的大相徑庭,這一點也不令人意外。
Google的研究總監(jiān)Peter Norvig早在1996年一篇名為“動態(tài)語言設(shè)計模式”的演講中,就指出了GoF所提出的23種設(shè)計模式,其中有16種在Lisp語言中已經(jīng)是天然的實現(xiàn)。比如,Command模式在Java中需要一個命令類,一個接收者類,一個調(diào)用者類。Command模式把運算塊封裝在命令對象的方法內(nèi),成為該對象的行為,并把命令對象四處傳遞。但在Lisp或者JavaScript這些把函數(shù)當作一等對象的語言中,函數(shù)便能封裝運算塊,并且函數(shù)可以被當成對象一樣四處傳遞,這樣一來,命令模式在Lisp或者JavaScript中就成為了一種隱形的模式。
在Java這種靜態(tài)編譯型語言中,無法動態(tài)地給已存在的對象添加職責(zé),所以一般通過包裝類的方式來實現(xiàn)裝飾者模式。但在JavaScript這種動態(tài)解釋型語言中,給對象動態(tài)添加職責(zé)是再簡單不過的事情。這就造成了JavaScript語言的裝飾者模式不再關(guān)注于給對象動態(tài)添加職責(zé),而是關(guān)注于給函數(shù)動態(tài)添加職責(zé)。
問:JavaScript有很多框架和庫,對于初級學(xué)習(xí)者來說,怎么能在這些資源中選擇適合自己的來創(chuàng)建個人技術(shù)棧?
相比于其他語言的開發(fā)者,JavaScript程序員確實會顯得比較“辛苦”。前端框架和庫的發(fā)展太快了,好像jQuery的流行還是昨天的事情,今天又涌現(xiàn)了Backbone、Angular、React這些框架。對初學(xué)者來說,很容易讓人迷茫,不知道學(xué)習(xí)哪個框架。我的建議是,優(yōu)先根據(jù)項目需求選擇,如果你接手的項目正在使用Angular.js,那就是學(xué)習(xí)Angular.js的好機會。
如果還有一些業(yè)余時間,可以選擇一些最流行的框架來學(xué)習(xí),它們之所以能夠在浩瀚的框架海洋中脫穎而出,肯定是有它們的優(yōu)點的。比如我們找準了Angular.js來學(xué)習(xí),可以先用Angular.js來做幾個demo頁面,然后想辦法在一個合適的項目中使用。熟悉語法之后可以閱讀它的源代碼,如果有時間和精力,可以模仿它寫一個類似的框架,在這個過程之后,或許你還可以對它加以改進。
問:AlloyTeam現(xiàn)在有多少人?由什么樣的工程師組成?
AlloyTeam目前有50多人,團隊既有94后的小鮮肉,也有70后的大叔,女前端工程師則既有美麗師姐、也有全民校花,還有萌妹子。大家的技術(shù)從Web前端、后端到客戶端,端端精通,既有對基礎(chǔ)框架有研究的同學(xué),也有對計算機圖形處理感興趣的同學(xué),既有喜歡做工具的,也有喜歡做游戲的,技術(shù)專長可謂兼容并包。
問:AlloyTeam的名字從何而來?你們團隊的主要工作內(nèi)容是什么?
我們團隊的代號叫AlloyTeam,很多人很好奇騰訊AlloyTeam名字的含義和由來,其實這里還真有一段小歷史。2008那年我們團隊開始研發(fā)WebQQ,WebQQ是業(yè)界首個將WebOS、云計算、AppStore和Web開放平臺整合在一起的產(chǎn)品,所以我們就給WebQQ起了一個開發(fā)代號——AlloyOS。Alloy是合金、合鑄、合成、聚合的意思,正好寓意我們的WebQQ是將公司內(nèi)、外的各種互聯(lián)網(wǎng)服務(wù)產(chǎn)品合鑄成一個為用戶提供一站式的在線生活的WebOS平臺。所以我們的團隊也就自然成了AlloyTeam,同時AlloyTeam這名字還有一個寓意:就是將不同成員的聰明才智,以及不同技術(shù)聚合在一起,以產(chǎn)生更強的合金特性,從而成為堅不可摧的團隊。
目前我們團隊主要負責(zé)手機QQ中的移動Web業(yè)務(wù)以及Hybrid App的開發(fā)工作,比如:興趣部落、QQ群等等。除了日常業(yè)務(wù)開發(fā)之外,也鼓勵大家做一些各個方面的自由開源項目,不管是可以提高大家工作效率的開發(fā)工具,還是能對業(yè)界產(chǎn)生影響力的開源項目,小到組件,大到游戲,我們都非常支持大家去做。團隊內(nèi)部非常平等和自由,也鼓勵大家分享、布道、寫書。另外,AlloyTeam也隨時歡迎優(yōu)秀的Web前端小伙伴加入。
問:如今,移動互聯(lián)網(wǎng)已經(jīng)變得越來越重要,在這種情況下前端工程師會面臨什么樣的機會和挑戰(zhàn)?
的確是這樣,就我個人而言,除了上班時間已經(jīng)很少打開電腦了。原先用PC能做的事情,現(xiàn)在手機幾乎全部可以完成,可以預(yù)見這個趨勢在將來還會更加明顯。在這種情況下,原先在PC上開發(fā)的前端工程師很多都轉(zhuǎn)向了移動web開發(fā)。包括AlloyTeam也是這樣,現(xiàn)在絕大部分時間都在做移動端開發(fā)。對于前端工程師來說,可能要學(xué)習(xí)一些新的知識,這不是壞事,也不難,程序員應(yīng)該保持學(xué)習(xí)的心態(tài)。不管是PC開發(fā)還是移動開發(fā),我們都在用相同的方式來改變?nèi)藗兊纳睢?/p>
問:程序員給人的印象通常都是不善交際、不善運動,生活習(xí)慣不規(guī)律,這些習(xí)慣也潛移默化地影響著程序員群體的健康。你在業(yè)余時間是一位健身教練,請問運動帶給你的好處都有哪些?
我認識許多非常有才的程序員,程序員是一個相當聰明的群體,聰明的人能做好許多事情,而不是僅僅寫代碼。不過也許大部分人都把太多重心放在了工作上面,這是好事,但也不全是好事。程序員的職業(yè)特點注定對健康的損害比較大,從25歲開始人的器官開始不可逆轉(zhuǎn)的老化之后,久坐和不運動帶來的危害更大。所以程序員更要有意識地多運動,至少運動會給你一個跳動更強烈的心臟,可以背女朋友越過某個路上的小水溝。當然,加班趕項目的時候也比別人抗得久。
問:請問對于程序員來說,工作和運動是否有可以兼顧?對于想要積極鍛煉的程序員來說,你有哪些建議?
IT行業(yè)基本上只能在大城市生活和工作。大城市的房價物價注定我們工作得努力和辛苦。這種情況下,許多人完全把太多精力放在了工作上面,而忽略了生活本身。工作本該只是生活的一部分,也許我們應(yīng)該有一個更加平和的心態(tài),努力工作和享受生活并不矛盾。在業(yè)余時間有一些自己的愛好,或是找一點適合自己的運動,不光是為了更好的工作,還因為這些愛好本身也是生活的另一部分。
對于開始有意識開始鍛煉的程序員,這是一個很好的起點。不過現(xiàn)實中的大部分人情況都是三天打魚兩天曬網(wǎng)。如果真想通過運動來改善體質(zhì)或者豐富業(yè)余生活,首先一定要保證自己能堅持下來。很多人剛開始鍛煉的時候非常有激情,一段時間后就被自己以各種理由說服放棄了鍛煉,比如要加班,有約會,感冒了,有聚餐各種各樣的原因。這些事情肯定是會遇到的,但不管怎樣,一周抽出5個小時來鍛煉身體其實肯定是沒問題的。
其次,不管什么運動都是一門科學(xué)。拿健身來講,首先要搞清楚身體跟新陳代謝有關(guān)的基本知識,搞清楚動作標準,這樣才會有效果而且不容易弄傷關(guān)節(jié)和肌肉。如果有條件的話,可以去健身房里面請一個專業(yè)教練,有教練和沒有教練的區(qū)別太大了。相信堅持一段時間后,都能看到自己形貌和精神的改變,直到健身成為一種習(xí)慣。
更多精彩,加入圖靈訪談微信!文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/85824.html
摘要:策略模式可以避免代碼中的多重判斷條件。策略模式在程序中或多或少的增加了策略類。此文僅記錄本人閱讀設(shè)計模式與開發(fā)實踐這個本時的感受,感謝作者曾探寫出這么好的一本書。設(shè)計模式中很重要的一點就是將不變和變分離出來。參考設(shè)計模式與開發(fā)實踐曾探 策略模式的定義是:定義一系列的算法,把它們一個個封裝起來,并且是它們可以相互替換。 策略模式可以避免代碼中的多重判斷條件。 策略模式很好的體現(xiàn)了開放-...
摘要:詞云可以通過網(wǎng)站紐扣詞云來制作,然而可以通過代碼來實現(xiàn),下面開始吧。 詞云可以通過網(wǎng)站 https://wordart.com/ 紐扣詞云http://cloud.niucodata.com/ 來制作,然而 Python 可以通過代碼來實現(xiàn),下面開始吧。 showImg(https://segmentfault.com/img/bVQzIx?w=874&h=416); pip inst...
摘要:然而這次的文章,就像賀師俊所說的這篇文章是從程序員這個老年度總結(jié)前端掘金年對我來說,是重要的一年。博客導(dǎo)讀總結(jié)個人感悟掘金此文著筆之時,已經(jīng)在眼前了。今天,我就來整理一篇,我個人認為的年對開發(fā)有年終總結(jié)掘金又到 2016 Top 10 Android Library - 掘金 過去的 2016 年,開源社區(qū)異常活躍,很多個人與公司爭相開源自己的項目,讓人眼花繚亂,然而有些項目只是曇花一...
閱讀 1035·2023-04-26 02:26
閱讀 2148·2021-09-26 10:16
閱讀 1554·2019-08-30 12:57
閱讀 3468·2019-08-29 16:10
閱讀 3222·2019-08-29 13:47
閱讀 1189·2019-08-29 13:12
閱讀 2141·2019-08-29 11:11
閱讀 1337·2019-08-26 13:28