隨著互聯(lián)網(wǎng)的發(fā)展和程序員的高薪待遇,越來越多的年輕人畢業(yè)后都會(huì)選擇從事軟件編程的工作,那么,你知道那些頂級(jí)的程序員有哪些特質(zhì)嗎?你知道你只是一個(gè)普通程序員的原因嗎?藍(lán)鷗資深講師總結(jié)了5個(gè)頂級(jí)程序員和普通程序員的最大區(qū)別,一起來看一下吧!
1. 勇于去研究你不懂的代碼
一般人都不愿意去研究自己不曾接觸過的代碼,很多人都沒有嘗試就放棄了。如果你經(jīng)常去研究你沒有接觸過的代碼,你就會(huì)越來越熟悉不同的代碼結(jié)構(gòu)和設(shè)計(jì)模式?,F(xiàn)在人們很容易就接觸到優(yōu)秀的開源代碼資源,你可以很方便的就下載下來做一些改動(dòng)或者調(diào)試,去研究為什么代碼可以這么寫。
除了代碼之外,很多人對(duì)于陌生的工作內(nèi)容也會(huì)感到恐懼。每次換工作的時(shí)候,你可能都會(huì)遇到新公司的工作內(nèi)容和以前工作的內(nèi)容不一樣的情況,以至于剛開始的時(shí)候工作效率沒有以前那么高。很多人甚至覺得,他們是不是騙了面試官。
其實(shí),大家都是在學(xué)習(xí)的過程中。在一個(gè)陌生的領(lǐng)域,沒有人從一開始就是大神。如果你想變得越來越好,無論是寫代碼,與人溝通或者其它的技能,都是需要投入時(shí)間去學(xué)習(xí)的。
2. 精通代碼調(diào)試(debug)
很多人在寫代碼的過程中,經(jīng)常會(huì)有的一個(gè)問題就是:為什么我寫出來的代碼不能運(yùn)行?為什么運(yùn)行的結(jié)果不是我想要的?
幾乎所有的程序員寫代碼都不是一遍就能寫好的。但是頂尖的程序員非常快的就明白自己代碼的問題可能是什么。這是一個(gè)很重要的能力,但是偏偏學(xué)校里不教,面試的時(shí)候考官也不經(jīng)常提及。
那么怎么去調(diào)試代碼呢?其實(shí)核心就是以下幾個(gè)方法:
不妨先猜測(cè)一下到底發(fā)生了什么。
假設(shè)你的猜測(cè)是對(duì)的,想想你的猜測(cè)會(huì)導(dǎo)致程序有什么結(jié)果。
試著觀察這些結(jié)果有沒有異常的地方。
如果你沒有發(fā)現(xiàn)異樣,那么說明你的猜測(cè)就是對(duì)的。
如果你發(fā)現(xiàn)了異樣,那么說明你的猜測(cè)是錯(cuò)的,接下來?yè)Q一個(gè)猜測(cè)試試。
對(duì)于頂尖程序員來說,這個(gè)過程在腦海中就是電光火石的一瞬間。只要你解決的問題足夠多,你做出來的猜測(cè)就會(huì)越準(zhǔn)確。
至于如何發(fā)現(xiàn)異樣?你就需要有一套自己的工具或者方法論了。最簡(jiǎn)單的就是在代碼里輸出日志來判斷。但是這是比較笨的辦法,你需要去接觸一些高級(jí)的工具或者直接帶有Debug功能的編輯器。
3. 重視能夠節(jié)約時(shí)間的工具
最近打敗人類的AlphaGo每天可以進(jìn)行上百萬局的下棋訓(xùn)練,我們?nèi)祟愐蝗f個(gè)小時(shí)的訓(xùn)練卻需要10年之久。也就是說,電腦運(yùn)行幾分鐘,可能就等于人類工作好幾年。
曾經(jīng)在Facebook擔(dān)任技術(shù)總監(jiān)的Bobby Johnson描述過,高效率的程序員都把時(shí)間花在制作工具上。
很多人也認(rèn)為工具是很重要的,但是他們并沒有花時(shí)間去制作、整合自己的工具。但是,Jonson團(tuán)隊(duì)最出色的員工耗費(fèi)了他們1/3的時(shí)間在工具制作上,這些工具可以用來發(fā)布代碼,監(jiān)控系統(tǒng),以及能讓他們花更少的時(shí)間去做更多事情。
總之,不要花時(shí)間去做機(jī)器可以代替你去做的事情。
4. 優(yōu)化你的迭代速度
假設(shè)你要花12秒鐘去搜索某個(gè)函數(shù)是在哪里定義的。再假設(shè)你每天做這個(gè)動(dòng)作60次,那么你每天就要花12分鐘去搜索函數(shù)定義。
如果你用一個(gè)好一點(diǎn)的編輯器,每次找到函數(shù)定義只要2秒鐘,那么你每天就會(huì)節(jié)約10分鐘。每年你就可以節(jié)約40個(gè)小時(shí)。
如果你能找到3個(gè)這樣的場(chǎng)景去優(yōu)化一下,那么你每年可以節(jié)約一個(gè)月的時(shí)間。想想這一個(gè)月你可以做多少有意義的事情。
再假如你在調(diào)試一個(gè)App的bug的時(shí)候,改完一次代碼都需要重啟一下App,然后點(diǎn)擊4、5次才能看到bug有沒有改好。那么你是不是可以先花幾分鐘設(shè)置以下,讓App一啟動(dòng)就轉(zhuǎn)到顯示Bug的頁(yè)面呢?
千萬不要小看這些瑣碎的細(xì)節(jié),改善它們的回報(bào)是巨大。
5. 系統(tǒng)性的思考方式
當(dāng)你在寫代碼的時(shí)候,你很容易就認(rèn)為只要你按照需求實(shí)現(xiàn)了指定的功能,你的代碼就寫完了。但是這其實(shí)只是冰山一角。任何沒有發(fā)布到生產(chǎn)環(huán)境的代碼都不會(huì)產(chǎn)生任何價(jià)值。
如果想寫出真正有影響力的代碼,你需要從整個(gè)系統(tǒng)去理解你的工作:
你的代碼和其他人寫的代碼在功能上是什么關(guān)系?
你有沒有好好測(cè)試你的代碼?或者其他人是否很容易測(cè)試你的代碼?
為了部署你的代碼,線上生產(chǎn)環(huán)境的代碼是不是需要改動(dòng)?
新的代碼會(huì)不會(huì)影響到已經(jīng)運(yùn)行的代碼?
在新的功能下,你的目標(biāo)用戶的行為是不是你期望的?
你的代碼有沒有產(chǎn)生商業(yè)上的影響?
這些問題都不是很容易就能回答的,但是在寫代碼的時(shí)候,你需要明白你的代碼最后會(huì)不會(huì)得到最好的結(jié)果。