《The Effective Engineer》的作者在寫書的過程中科平,為了了解那些頂級程序員和普通程序員的區(qū)別锨匆,采訪了很多硅谷頂級科技公司的頂尖軟件工程師崭别。他發(fā)現(xiàn)這些給世界帶來巨大影響的的工程師們至少有以下5個共同的思維模式:
1.勇于去研究你不懂的代碼
一般人都不愿意去研究自己不曾接觸過的代碼,很多人都沒有嘗試就放棄了恐锣。如果你經(jīng)常去研究你沒有接觸過的代碼茅主,你就會越來越熟悉不同的代碼結構和設計模式。現(xiàn)在人們很容易就接觸到優(yōu)秀的開源代碼資源土榴,你可以很方便的就下載下來做一些改動或者調(diào)試诀姚,去研究為什么代碼可以這么寫。
除了代碼之外玷禽,很多人對于陌生的工作內(nèi)容也會感到恐懼赫段。每次換工作的時候,你可能都會遇到新公司的工作內(nèi)容和以前工作的內(nèi)容不一樣的情況矢赁,以至于剛開始的時候工作效率沒有以前那么高糯笙。很多人甚至覺得,他們是不是騙了面試官撩银。
其實给涕,大家都是在學習的過程中。在一個陌生的領域额获,沒有人從一開始就是大神够庙。如果你想變得越來越好,無論是寫代碼咪啡,與人溝通或者其它的技能首启,都是需要投入時間去學習的。
2.精通代碼調(diào)試(debug)
很多人在寫代碼的過程中撤摸,經(jīng)常會有的一個問題就是:為什么我寫出來的代碼不能運行?為什么運行的結果不是我想要的?
幾乎所有的程序員寫代碼都不是一遍就能寫好的毅桃。但是頂尖的程序員非常快的就明白自己代碼的問題可能是什么准夷。這是一個很重要的能力钥飞,但是偏偏學校里不教,面試的時候考官也不經(jīng)常提及衫嵌。
那么怎么去調(diào)試代碼呢?其實核心就是以下幾個方法:
>>不妨先猜測一下到底發(fā)生了什么读宙。
>>假設你的猜測是對的,想想你的猜測會導致程序有什么結果楔绞。
>>試著觀察這些結果有沒有異常的地方结闸。
>>如果你沒有發(fā)現(xiàn)異樣唇兑,那么說明你的猜測就是對的。
>>如果你發(fā)現(xiàn)了異樣桦锄,那么說明你的猜測是錯的扎附,接下來換一個猜測試試。
對于頂尖程序員來說结耀,這個過程在腦海中就是電光火石的一瞬間留夜。只要你解決的問題足夠多,你做出來的猜測就會越準確图甜。
至于如何發(fā)現(xiàn)異樣?你就需要有一套自己的工具或者方法論了碍粥。最簡單的就是在代碼里輸出日志來判斷。但是這是比較笨的辦法黑毅,你需要去接觸一些高級的工具或者直接帶有Debug功能的編輯器嚼摩。
3.重視能夠節(jié)約時間的工具
最近打敗人類的AlphaGo每天可以進行上百萬局的下棋訓練,我們?nèi)祟愐蝗f個小時的訓練卻需要10年之久矿瘦。也就是說低斋,電腦運行幾分鐘,可能就等于人類工作好幾年匪凡。
曾經(jīng)在Facebook擔任技術總監(jiān)的Bobby Johnson描述過膊畴,高效率的程序員都把時間花在制作工具上。
很多人也認為工具是很重要的病游,但是他們并沒有花時間去制作唇跨、整合自己的工具。但是衬衬,Jonson團隊最出色的員工耗費了他們1/3的時間在工具制作上买猖,這些工具可以用來發(fā)布代碼,監(jiān)控系統(tǒng)滋尉,以及能讓他們花更少的時間去做更多事情玉控。
總之,不要花時間去做機器可以代替你去做的事情狮惜。
4.優(yōu)化你的迭代速度
假設你要花12秒鐘去搜索某個函數(shù)是在哪里定義的高诺。再假設你每天做這個動作60次,那么你每天就要花12分鐘去搜索函數(shù)定義碾篡。
如果你用一個好一點的編輯器虱而,每次找到函數(shù)定義只要2秒鐘,那么你每天就會節(jié)約10分鐘开泽。每年你就可以節(jié)約40個小時牡拇。
如果你能找到3個這樣的場景去優(yōu)化一下,那么你每年可以節(jié)約一個月的時間。想想這一個月你可以做多少有意義的事情惠呼。
再假如你在調(diào)試一個App的bug的時候导俘,改完一次代碼都需要重啟一下App,然后點擊4剔蹋、5次才能看到bug有沒有改好趟畏。那么你是不是可以先花幾分鐘設置以下,讓App一啟動就轉(zhuǎn)到顯示Bug的頁面呢?
千萬不要小看這些瑣碎的細節(jié)滩租,改善它們的回報是巨大。
5.系統(tǒng)性的思考方式
當你在寫代碼的時候利朵,你很容易就認為只要你按照需求實現(xiàn)了指定的功能律想,你的代碼就寫完了。但是這其實只是冰山一角绍弟。任何沒有發(fā)布到生產(chǎn)環(huán)境的代碼都不會產(chǎn)生任何價值技即。
如果想寫出真正有影響力的代碼,你需要從整個系統(tǒng)去理解你的工作:
>>你的代碼和其他人寫的代碼在功能上是什么關系?
>>你有沒有好好測試你的代碼?或者其他人是否很容易測試你的代碼?
>>為了部署你的代碼樟遣,線上生產(chǎn)環(huán)境的代碼是不是需要改動?
>>新的代碼會不會影響到已經(jīng)運行的代碼?
>>在新的功能下而叼,你的目標用戶的行為是不是你期望的?
>>你的代碼有沒有產(chǎn)生商業(yè)上的影響?
這些問題都不是很容易就能回答的,但是在寫代碼的時候豹悬,你需要明白你的代碼最后會不會得到最好的結果葵陵。
這些只是頂尖程序員的一些基本思維方式,如果你想要更詳細的了解在Google瞻佛,F(xiàn)acebook脱篙,Twitter這些公司的頂尖程序員是如何工作的,去關注作者的博客或者他的書吧伤柄。
原文鏈接:http://mp.weixin.qq.com/s/-UPszr4JPrlQk3yZpTzYmA