年薪100萬(wàn)和10萬(wàn)程序員的差距
我們看武俠大片,經(jīng)常有那種本來(lái)可以練就絕世武功的大蝦。
陰差陽(yáng)錯(cuò)練的走火入魔。
一開(kāi)始還可以硬撐,還能打敗一些蝦兵蟹將。遇見(jiàn)真正的高手,這些大蝦們立馬就敗下陣來(lái)。其實(shí)程序員的職業(yè)生涯,如同練功一般。先學(xué)馬步,再學(xué)輕功,最后用氣功各種殺怪制敵。這個(gè)過(guò)程中,很多程序員一不小心走火入魔了。
時(shí)間一長(zhǎng),不僅內(nèi)力毫無(wú)長(zhǎng)進(jìn)、甚至連已經(jīng)會(huì)的招式也慢慢荒廢。今天和大家聊聊蹩足程序員和優(yōu)秀程序員的差距。
一、復(fù)制粘貼哥
不少程序員喜好復(fù)制網(wǎng)上的各種實(shí)現(xiàn)。又或者扒拉同事的代碼功能,原封不動(dòng)的粘貼過(guò)來(lái)。他們長(zhǎng)期靠著復(fù)制粘貼行走于程序江湖。運(yùn)氣好的時(shí)候,快速弄完上線居然還沒(méi)有Bug。運(yùn)氣不好的時(shí)候呢?編譯問(wèn)題就夠吃一壺了。更絕的是不少?gòu)?fù)制的錯(cuò)誤代碼一直伴隨著線上系統(tǒng)的整個(gè)生命周期。曾經(jīng)有兩個(gè)巨頭公司,扯皮打官司。原因是某巨頭指責(zé)另一家抄襲代碼。巨頭的證據(jù)很充分,反編譯對(duì)手的代碼后,發(fā)現(xiàn)了完全一致的注釋彩蛋。
不用懷疑,這一定是「復(fù)制粘貼程序員」的卓絕貢獻(xiàn)。在商業(yè)大戰(zhàn)的關(guān)鍵時(shí)刻,給競(jìng)爭(zhēng)對(duì)手遞了把好刀子。這類程序員還有一個(gè)特點(diǎn):喜好吹噓自己碼代碼能力一流,諸如一天能寫2000行!其實(shí)做過(guò)程序員的都知道,正兒八經(jīng)一天幾百行代碼,基本就是極限了。但是「復(fù)制粘貼程序員」可就不一樣了。幾分鐘2000行都不是不可能的事。甚至一天給你干出上萬(wàn)行代碼,也不在話下。洋哥為什么這么清楚?吃他們的虧,真不少。
以至于最后形成了條件反射,面試程序員的時(shí)候,我都會(huì)問(wèn)一句:請(qǐng)問(wèn)你一天能寫多少行代碼呀?回答明顯不靠譜的,一律PASS...!這還讓我養(yǎng)成了一個(gè)習(xí)慣,只要是程序員崗位,甭管你多高級(jí)。
手寫一段算法代碼是必須的,完全寫不出來(lái)也PASS。除了對(duì)團(tuán)隊(duì)的危害,長(zhǎng)期依賴「復(fù)制粘貼」的程序員,個(gè)人成長(zhǎng)也會(huì)受到極大影響。
用這種方式來(lái)實(shí)現(xiàn)功能就像鴉片一般,會(huì)上癮。別人絞盡腦汁寫一天,他5分鐘就搞定了,你說(shuō)爽不爽?長(zhǎng)期舒爽的代價(jià)是失去裸編程能力、代碼結(jié)構(gòu)化能力、分析能力,進(jìn)而失去了職場(chǎng)競(jìng)爭(zhēng)力。讓他寫一個(gè)冒泡算法的實(shí)現(xiàn),他都需要去網(wǎng)上搬救兵。遇見(jiàn)沒(méi)有現(xiàn)成代碼能搞定的工程,直接傻眼。
二、輪子哥
每個(gè)程序員在成長(zhǎng)初期,都會(huì)經(jīng)歷過(guò)造輪子的階段。
我們學(xué)習(xí)編碼的時(shí)候,都會(huì)照書(shū)上的示范造一個(gè)又一個(gè)的小輪子。
我們學(xué)習(xí)某些新技術(shù),拿到源碼拆解重寫的過(guò)程,也是在造輪子。
這些「無(wú)用勞動(dòng)」讓我們真正掌握了編碼的精髓,這是拆解-重建-掌握的過(guò)程。
多年前,拿到google的大量源碼,我也是照貓畫虎,挨個(gè)功能實(shí)現(xiàn)一遍。
但不少程序員在做業(yè)務(wù)的過(guò)程中,瘋狂造輪子,這就是很大問(wèn)題了。
在業(yè)務(wù)開(kāi)發(fā)中,明知道你做的組件或功能不可能比已經(jīng)存在的組件做得更好,卻仍然堅(jiān)持要做,并應(yīng)用到業(yè)務(wù)中。
簡(jiǎn)單點(diǎn)說(shuō):業(yè)界已經(jīng)有公認(rèn)的軟件或者庫(kù)了,卻還要自己實(shí)現(xiàn)一個(gè)勉強(qiáng)運(yùn)行的山寨版。
每個(gè)造輪子的程序員都有自己“不得不造”的理由。比如:
- 我的需求獨(dú)一無(wú)二,現(xiàn)有的庫(kù)就是在某些方面上滿足不了
- 用老輪子太麻煩,還要看接口文檔,文檔寫的太狗屎
- 別人已經(jīng)有輪子了?我不管,我就要自己實(shí)現(xiàn),這樣才有掌控感
- 造輪子的過(guò)程能鍛煉我的能力,讓我提升編碼水平
- 自己干多有成就感,我不想當(dāng)一個(gè)搭積木的工程師!
遇見(jiàn)這樣的程序員,滿足了他自己,坑了一個(gè)團(tuán)隊(duì)。
尤其是在互聯(lián)網(wǎng)行業(yè),時(shí)間就是商機(jī)、迭代速度就是擊敗對(duì)手的武器。
更別提有人放著圓形的輪子不用,非造出個(gè)方形輪子,直接導(dǎo)致翻車。
很多時(shí)候,造輪子程序員其實(shí)是在拿團(tuán)隊(duì)的資源,提升自己。
在我看來(lái),這是一種高級(jí)摸魚(yú)行為,但危害程度遠(yuǎn)大于低級(jí)摸魚(yú)。公司和老板都不是傻子,識(shí)破后,輪子程序員也就失去了在公司的發(fā)展前景。最可怕的是那種進(jìn)化到架構(gòu)師的輪子程序員,搖身一變成為輪子架構(gòu)師。那么這種危害就從一個(gè)工程團(tuán)隊(duì)擴(kuò)大到整個(gè)公司。比如曾經(jīng)帶過(guò)的一個(gè)輪子架構(gòu)師,不顧業(yè)務(wù)發(fā)展的階段和公司體量,上來(lái)就要設(shè)計(jì)一個(gè)類KFK的日志系統(tǒng)。
不讓他做,還會(huì)跟你分析各種KFK的硬傷。無(wú)論是輪子程序員還是輪子架構(gòu)師,如果不改變瘋狂造輪子的習(xí)慣,被淘汰只是時(shí)間問(wèn)題。
三、布道哥
技術(shù)布道師本身是個(gè)很高大的職業(yè)。
很多公司的CTO同時(shí)也擔(dān)任技術(shù)布道的工作。
這是個(gè)對(duì)技術(shù)深度理解和溝通能力都有極高要求的崗位。
很遺憾的是,不少程序員代碼寫的無(wú)比蹩足、溝通能力也很一般,但偏偏喜歡上了布道的感覺(jué)。
用了點(diǎn)新技術(shù)就急不可耐的到處宣傳,資深同事忽悠不了,就去忽悠剛?cè)肼毜男∧贻p。
又或者是手撕產(chǎn)品經(jīng)理的時(shí)候,不自覺(jué)的蹦出各種聽(tīng)不懂的技術(shù)名稱,還假模假樣的給人解釋技術(shù)細(xì)節(jié)。
業(yè)內(nèi)出現(xiàn)了新的語(yǔ)言,他們一定會(huì)急吼吼的去學(xué)習(xí)。
剛寫了個(gè)"Hellow World”,就急不可耐的到處宣稱掌握了這門語(yǔ)言的精髓和真理。
他們經(jīng)常號(hào)稱掌握10種編程語(yǔ)言,且對(duì)每一種語(yǔ)言的優(yōu)缺點(diǎn)都能分析的頭頭是道。
你讓他們?cè)诠こ讨袘?yīng)用起來(lái)?那是不可能的,他們只負(fù)責(zé)布道。
一般來(lái)說(shuō),團(tuán)隊(duì)里有一個(gè)這種類型的工程師,就夠吃一壺了。
要是有好幾個(gè),他們還會(huì)抱團(tuán)進(jìn)行學(xué)習(xí)交流,甚至組織研討會(huì)。
各種新技術(shù)、新名詞、新動(dòng)向,在他們這,都被安排的明明白白的。
但絕不產(chǎn)生任何業(yè)務(wù)價(jià)值!
— 4 —優(yōu)秀程序員
三類蹩足程序員就說(shuō)完了。
程序員行業(yè)有一個(gè)特點(diǎn):優(yōu)秀程序員的產(chǎn)出是普通程序員的好多倍,甚至是10倍!這是因?yàn)榫幊滩皇且婚T「線性科學(xué)」,而是一門「非線性科學(xué)」。
「線性科學(xué)」,比如跑步的速度就是,世界冠軍的速度也不可能是普通人的10倍?!阜蔷€性科學(xué)」是指很多種因素交匯在一起,極大增加了系統(tǒng)的復(fù)雜度。
而蹩足的程序員實(shí)際上還有副作用,不少團(tuán)隊(duì)光是處理前人埋下的坑,就耗費(fèi)了全部精力。
成為優(yōu)秀程序員不易,我們首先要避開(kāi)「復(fù)制粘貼」、「造輪子」、「布道」這三個(gè)陷阱。
進(jìn)一步,我們要做到以下7點(diǎn):
1.具備裸編程能力
處理程序?qū)嶋H實(shí)現(xiàn)部分的子任務(wù),實(shí)現(xiàn)函數(shù)或者算法之類的能力。
聽(tīng)起來(lái)很簡(jiǎn)單對(duì)吧?實(shí)際上很多程序員缺失這樣的能力。
2.具備強(qiáng)悍的調(diào)試能力
調(diào)試能力某種程度上比編碼能力更重要。查找和解決BUG會(huì)占用程序員大量的時(shí)間。
查找BUG產(chǎn)生的根源不是一件簡(jiǎn)單的事情,需要整體的分析和經(jīng)驗(yàn)的沉淀,同時(shí)還需要對(duì)各種調(diào)試工具熟練應(yīng)用。
3.追求簡(jiǎn)悅
代碼的注釋是否恰到好處、函數(shù)模塊和類的結(jié)構(gòu)是否能讓其他人直接秒懂、架構(gòu)的設(shè)計(jì)是否足夠清晰等等,都屬于程序員追求簡(jiǎn)約的范疇。
4.準(zhǔn)確預(yù)計(jì)工期的能力
老板想了個(gè)idea授意產(chǎn)品經(jīng)理估工期。產(chǎn)品經(jīng)理原型都沒(méi)畫出來(lái),只有個(gè)大概想法,就找技術(shù)排工期。
這個(gè)時(shí)候,技術(shù)的內(nèi)心大概多了幾道菜式:清蒸產(chǎn)品經(jīng)理、紅燒產(chǎn)品總監(jiān)、油炸CTO。其實(shí)準(zhǔn)確預(yù)測(cè)技術(shù)工期是程序員一項(xiàng)非常重要的能力。為什么這么說(shuō)?只有具備這項(xiàng)能力,才能讓開(kāi)發(fā)工作游刃有余、可進(jìn)可退。
5.理解底層系統(tǒng)原理
比如數(shù)據(jù)結(jié)構(gòu)、網(wǎng)絡(luò)協(xié)議、操作系統(tǒng)相關(guān)知識(shí),等等。
程序的很多問(wèn)題都是源于對(duì)計(jì)算機(jī)工作原理的誤解,即使是使用高級(jí)語(yǔ)言開(kāi)發(fā)的程序也一樣。
另外,一些更偏應(yīng)用層的架構(gòu)或框架,基礎(chǔ)一定是更底層的系統(tǒng)。
6.嚴(yán)格把控關(guān)鍵設(shè)計(jì)
無(wú)論是大的系統(tǒng)還是小的模塊,一定都有最關(guān)鍵的功能。要在最關(guān)鍵功能上投入大量設(shè)計(jì)時(shí)間,才能規(guī)避開(kāi)發(fā)過(guò)程中的各種坑。
7.拒絕完美主義
完美主義包含兩種情況,一種是追求極致性能的工程師文化、還有一種是個(gè)人性格使然。無(wú)論哪一種,過(guò)分追求完美都會(huì)對(duì)業(yè)務(wù)交付產(chǎn)生影響。
程序員之間的差距,恐怕要比人類和猿猴之間的差距,還要大。
程序員讀者朋友們,留言說(shuō)說(shuō)你是哪類程序員吧?