程序員高效編程的14點建議
下面是開發(fā)大牛總結的高效編程的14點經驗。不管你是編程菜鳥還是資深程序員,或許都能從中得到啟發(fā)。
計劃
所謂plan,其實就是對于編程中的“設計”階段,當然,這里的plan并不像設計那樣重量級。它要求我們程序員在正式編程前最少要考慮一下下面的問題:
你這個程序,工具或是項目的目的,究竟是用來干什么的。你只有知道做什么,要達到什么樣的目的,你才能做得好,做得對。
需要有什么樣的功能。需要你給出來個功能表。這樣可以保證我們不會遺漏了什么。
準備好一些技術難題的前期調查和解決方案。不要等到開始編程的時候才去想。
下面是你因為有“plan”而得到的好處:
你能夠清楚地明白你要做的東西長什么樣?
你能清楚知道你要開發(fā)的東西要干些什么事?
你能夠在開發(fā)工程中解決你所有可能發(fā)生的難題。
使用偽代碼
偽代碼是一個非常不錯的方式,讓你可以看到你要寫得程序長什么樣?
一些人并不喜歡偽代碼,因為他們并不想把同樣的代碼寫兩遍,一遍是偽代碼,一遍是真代碼。其實,這是可以理解的,因為兩個copy的東西是比較不好維護的。但是我想,這是可以權衡的,如果的算法很簡單,那么就不需要偽代碼了,如果你的算法比較復雜,比較繞,那么,有一個偽代碼提綱挈領將會是一件非常不錯的事情,因為他有利于讓別人從一個簡單的文檔來了解一個復雜的算法或系統(tǒng)。這就好像一個電線的布線圖一樣,你可以很容易地通過一個簡單的文檔從復雜的實現(xiàn)中找到頭緒。
讓你身邊的人也高效起來
這個是我直到今天才感悟到的。我一直努力讓自己更加高效,不讓時間虛度。然而當我們面臨越來越復雜,越來越繁瑣的任務時,我們不得不借助于團隊。道理我都懂,然而卻一直不上心。我們一直說團隊是最重要的,然而我們終究并沒有把心思完全放在團隊上,為了自己的那點小九九。
只有身邊的人也如你般高效,才可能釋放出你來去做更多讓更多人高效起來的事。更多的人更加高效,即節(jié)約了他們的生命,也反過來再次讓你變得高效。
當你能夠讓身邊的人也越來越高效,或許你就真的到了高效的最高境界。
高效的開發(fā)環(huán)境
我們可以從編緝器談起,這里有IDE vs Text Editor,有Vim vs Emacs,有Sublime vs Atom,那該如何選擇呢?在做選擇之前,我們先想想自己的目標。我們希望這是一個長期的投資,這款編緝器能被長期使用,在這個過程不斷的打磨,使其能完全適合自己的習慣,最大化編緝效率。如果程序員是俠客,編緝器則是他手中的劍。
雖然我是Vim的重度用戶,但我覺得當年選擇Vim時有欠考慮。如果讓我重選一次,我的第一選擇會是Emacs,第二選擇會是Atom。Emacs已存在30年,社區(qū)仍然活躍,其可擴展性在編緝器中無人能出其右。Emacs的腳本語言elisp又是lisp的一種dialect,我覺得對lisp的學習可以提升程序員對編程核心思想的理解。另一個加分點是Emacs由于其本身的高門檻及l(fā)isp特質,吸引了大批高質素的程序員,其社區(qū)可謂藏龍臥虎,更誕生了像Org-mode這樣神級的插件。
注釋和命名
編程的時候,可能時間緊任務中,而且項目對注釋或者命名沒有強制要求,很多程序員就偷懶。結果就是坑別人,也可能坑自己。所以,注釋一定要寫,不管是否有要求。命名一定要規(guī)范,杜絕拼音,一定要用英文(拼音有時候有歧義)。注釋和命名是一個程序員的逼格,不能偷懶。在多人項目中,建議偷偷學習一下同事的編碼規(guī)范。
把玩并掌握代碼
到了這一步,你可能會覺得你已經從這本書所給予的信息中提取出了全部。然而,你還是沒有把玩示例代碼并試著讓它以別的方式運行。試驗是學習的關鍵。將書本中的示例代碼試驗一下,是提升你技能的好方法。當你做了各種各樣的延伸時,你應該開始理解代碼的變化如何在整體上影響應用。這類知識無法通過其他方式學習——你需要通過試驗去精準地理解一門語言所提供的特性。
最后,你將開始創(chuàng)造出與書中代碼不太一樣的應用。這時,你走到了一個新的階段。在這個階段中,你開始自信地創(chuàng)建自己的應用,并且真正地理解了它們是如何運作的。
認真沉思
創(chuàng)造的過程,就是將你腦海中的代碼進行結構化,體現(xiàn)到實際中并用它們解決某個問題。想象一下,在辦公室里有兩個書桌,一個用于寫作(此Tip),一個用于編輯(Tip 7)。從書桌能望向窗外,你可以異想天開、開放思考,像追逐蝴蝶一樣追逐你腦海中的想法。
不要害怕散步,或者害怕嘗試可能是,也可能不是最好的最終解決方案。我最有生產能力的實習生之一,當想弄清楚她代碼下一步該怎樣寫,她喜歡在CMU的走廊上走路。編程就像寫作一樣,不僅僅是在屏幕上打字,更重要的是你腦中想的東西。所以在種植前,先為土壤施肥而慶祝,然后再澆水。
必須像工匠一樣寫夠十萬行代碼,又須像寫詩一樣來寫代碼
程序員像木工一樣,熟能生巧。程序員必須寫足夠代碼量的程序,才會有感覺,這是一個苦力活,沒有任何捷徑可走。
計算機是一門實踐性的科學,沒有動手能力做支撐,很難做出好的科研成果。我的一個學長是美國卡內基梅隆大學的博士,卡內基梅隆大學計算機系在全世界都非常出名,他說每個博士生必須寫十萬行代碼才能畢業(yè),卡內基梅隆大學博士生進任何一個大企業(yè)基本不用面試。而國內培養(yǎng)的大部分研究生、博士生,動手能力都偏弱。沒有寫過足夠代碼量的程序員,想成為高手是不可能的,只能紙上談兵!
那么,怎樣像寫詩一樣寫代碼呢?很簡單,買幾本經典的編程書,把書上所有例程全部重新寫一遍,逐個比較和書上范例的差距,一步一步改善自己編程的風格和技巧。時間長了,自然就能寫出像書上例程一樣的代碼,甚至可以比書上寫得好?;A扎實后,多看看Linux等系統(tǒng)級的源代碼,看看高手是如何寫的,就有感覺了。通讀一下MSDN中所有的資料,這樣就“讀書破萬卷,下筆如有神”。