華為資深工程師:碼農(nóng)很多,但程序員并不多......
春節(jié)假期,與幾位友人小聚,大家互道工作順利、平安健康云云......
期間一位馳騁商界多年的老友問(wèn):“你現(xiàn)在在華為做什么工作呀?”我很驕傲地說(shuō):”系統(tǒng)架構(gòu)師“,可是他卻愣了很久。
但當(dāng)我老婆在旁邊補(bǔ)上一句“碼農(nóng)“時(shí),老友瞬間秒懂,卻把我受傷的心孤獨(dú)地留在風(fēng)中凌亂。
作為與 UNIX 同年代的人,我當(dāng)初選擇計(jì)算機(jī)專(zhuān)業(yè)僅僅是因?yàn)樽サ绞裁淳蛯W(xué)什么罷了。
本科畢業(yè)遇到互聯(lián)網(wǎng)危機(jī),便沒(méi)有想法地去讀了研,研究生畢業(yè)找工作,面試官問(wèn)為什么要做軟件開(kāi)發(fā)。
答曰:“不給錢(qián)都喜歡做的事情,何況還給錢(qián)”,從此便踏入了編碼這一行,只是從來(lái)沒(méi)想到一做就是十幾年。
但凡一件事情做久了,無(wú)論成功與否,都會(huì)有一些真切的體驗(yàn)和心得。以前也讀過(guò)一些工作中如何成功、快樂(lè),諸如馬洛斯理論之類(lèi)的文章。
也許是因?yàn)樽约侯I(lǐng)悟能力比較差,唯一的收獲是慶幸自己當(dāng)初選擇了編碼作為自己的工作,因?yàn)榫幋a天生就具有讓人愉悅的工作內(nèi)容和工作氛圍,快樂(lè)如影隨從。
編碼世界:規(guī)則簡(jiǎn)單有效,粗暴卻***
從事編碼,可以鍛煉邏輯思維能力,教會(huì)你如何思考。就像學(xué)習(xí)法律一樣,學(xué)法律的人未必都是為了成為律師,但法律教會(huì)了你一種思維方式。
同樣的,通過(guò)編碼可以學(xué)習(xí)到這個(gè)世界上最嚴(yán)謹(jǐn)?shù)乃季S方法。因?yàn)樵诰幋a的世界里,對(duì)錯(cuò)是簡(jiǎn)單甚至絕對(duì)的。
只要敲下鍵盤(pán),計(jì)算機(jī)就會(huì)判定孰是孰非,0 或 1,規(guī)則簡(jiǎn)單有效,粗暴卻***。
從事編碼,可以獲得持續(xù)的創(chuàng)造力。跟寫(xiě)作、繪畫(huà)、作曲一樣,編碼也是一種創(chuàng)造性的工作。
只要有一臺(tái)計(jì)算機(jī),掌握了基本技能后,你便擁有了***的超能,便能隨心所欲地創(chuàng)造出新的東西,豐富和美好這個(gè)世界,是不是很棒?
更酷的是,編碼可以品味孤獨(dú)。除了跟別人交流、學(xué)習(xí),程序員大部分時(shí)間都是獨(dú)自在工作,只要雙手觸摸到鍵盤(pán),內(nèi)心頃刻便會(huì)變的寧?kù)o,多酷呀!
伴隨著鍵盤(pán)清脆的低吟,沉浸在一個(gè)人的世界里,跟煙雨蒙蒙天,一杯茶,一個(gè)人聽(tīng)著淅淅瀝瀝的雨聲品味孤獨(dú),簡(jiǎn)直有異曲同工之妙,多感性呀!
能夠選擇編碼作為工作的人,大部分都是喜歡為人處世簡(jiǎn)簡(jiǎn)單單的人:這群人有著天真爛漫的好奇心,雖不茍言笑,但卻內(nèi)心火熱,善于分享,樂(lè)于助人,甚至有時(shí)為了解決問(wèn)題、寧愿不眠不休,卻深以為樂(lè)……
跟這樣一群簡(jiǎn)單純粹的人在一起,我覺(jué)得世界上***的工作氛圍,也不過(guò)如此。
程序員的三個(gè)境界
但 IT 時(shí)代的膨脹已經(jīng)讓編碼工作如同文藝復(fù)興時(shí)的印刷匠一樣,編碼門(mén)檻越來(lái)越低。
例如,遍地《一周XX速成》、《20天XX精通》,仿佛會(huì)寫(xiě)代碼就成了程序員,這讓很多人認(rèn)為從事編碼工作就是碼農(nóng)。
其實(shí),印刷匠很多,成為大師的不多;碼農(nóng)很多,但程序員并不多。程序員不是碼農(nóng),碼農(nóng)也不是真正的程序員。
程序員在英文里對(duì)應(yīng)有三個(gè)單詞:Coder、Programmer 和 Software Engineer。
我覺(jué)得這三個(gè)詞,生動(dòng)形象地描述了程序員所需要經(jīng)歷的三個(gè)階段,或者說(shuō)三個(gè)境界:
- Coder。只要求能夠熟練使用編程環(huán)境,精通幾種編程語(yǔ)言、開(kāi)發(fā)框架和開(kāi)發(fā)庫(kù),擅長(zhǎng)寫(xiě)代碼就可以了。這個(gè)階段的程序員能夠按照既定的設(shè)計(jì)完成編碼。
- Programmer。要求在 Coder 的基礎(chǔ)之上,精通設(shè)計(jì)模式、算法實(shí)現(xiàn)和編碼技巧,并具備熟練應(yīng)用的能力,這個(gè)階段的程序員能夠獨(dú)立編碼解決現(xiàn)實(shí)問(wèn)題。
- Software Engineer:要求在掌握業(yè)務(wù)知識(shí)的前提下,理解為什么這么實(shí)現(xiàn),在綜合考慮架構(gòu)實(shí)現(xiàn),權(quán)衡開(kāi)發(fā)成本后,為解決業(yè)務(wù)問(wèn)題提出***方案,并能與業(yè)務(wù)人員順暢溝通,讓業(yè)務(wù)人員理解方案。
編碼工作達(dá)到這個(gè)階段,才能稱(chēng)得上是真正的程序員,才真正實(shí)現(xiàn)了從工作到職業(yè)的轉(zhuǎn)變。
不可否認(rèn),這個(gè)世界上有一些天才的程序員,他們喝著咖啡,哼著歌,便完成了上面三個(gè)階段的修煉。但絕大部分人,都需要為此付出巨大的時(shí)間和精力。
能否成為職業(yè)的程序員,影響因素和方法論很多,各種學(xué)習(xí)類(lèi)、技術(shù)類(lèi)的總結(jié)遍地都是:主動(dòng)思考、及時(shí)總結(jié)、制定規(guī)劃等。但我認(rèn)為其中最重要的是能否做到專(zhuān)注。
許多沒(méi)有達(dá)到第三個(gè)階段的程序員,就是因?yàn)槭艿礁鞣N因素誘惑,變得心猿意馬,不夠?qū)Wⅰ?/p>
因?yàn)椴粔驅(qū)W?,他們不在意做好自己本職工作,不在意錘煉自己的技能,不在意學(xué)習(xí)新興的技術(shù)。
慢慢的,他們會(huì)認(rèn)為從事編碼沒(méi)有出路,進(jìn)而毫無(wú)例外地把編程看成是體力勞動(dòng),只會(huì)粘貼拷貝代碼,知其然而不知其所以然,導(dǎo)致技術(shù)停滯不前。
在這樣的狀態(tài)下工作 5 年、10 年,對(duì)于他們來(lái)說(shuō),沒(méi)什么區(qū)別,程序員真的就是吃青春飯的碼農(nóng)。
程序員 VS 碼農(nóng):我們不一樣
要避免程序員變成碼農(nóng)要做到如下幾點(diǎn):
- 必須對(duì)編碼保持熱情,并持續(xù)學(xué)習(xí)。
- 必須保持好奇心,樂(lè)于探求事物本質(zhì)。
- 必須對(duì)所做的工作及時(shí)總結(jié),主動(dòng)優(yōu)化代碼,讓系統(tǒng)變得更加有機(jī)。
- 必須主動(dòng)嘗試更好的開(kāi)發(fā)方式、更先進(jìn)的工具,來(lái)提升開(kāi)發(fā)效率,并想辦法避免重復(fù)性的工作。
- 必須不斷改進(jìn)設(shè)計(jì),將編程變成創(chuàng)造性的工作。
只要通過(guò)這樣逐步地積累經(jīng)驗(yàn)和長(zhǎng)時(shí)間錘煉,知識(shí)體系才能構(gòu)建完備和豐富,才能避免淪落為碼農(nóng)。
幾年前,我曾經(jīng)重構(gòu)過(guò)一個(gè)模塊,從外部看模塊所在的系統(tǒng),都是類(lèi)似這樣的,簡(jiǎn)潔而漂亮:
但從程序員編碼實(shí)現(xiàn)的層面看,它實(shí)際上是這樣的:
這個(gè)設(shè)計(jì)在最初的版本沒(méi)有任何問(wèn)題,使用繼承擴(kuò)展管理對(duì)象的接口能力,但僅僅過(guò)了兩個(gè)版本,項(xiàng)目組 PL 說(shuō)實(shí)在撐不下去了。
增加一個(gè)接口,需要修改 200 多個(gè)地方,如果再過(guò)一個(gè)版本,估計(jì)要修改 400 多個(gè)地方了。
后來(lái)我把它改成這個(gè)樣子,使用聚合消除了耦合:
從代碼實(shí)現(xiàn)層面看,在功能剛開(kāi)始開(kāi)發(fā)時(shí),這兩個(gè)設(shè)計(jì)區(qū)別不是很大。
但隨著系統(tǒng)演進(jìn)、越來(lái)越多的功能加入,繼承關(guān)系帶來(lái)的耦合會(huì)導(dǎo)致模塊之間關(guān)系越來(lái)越復(fù)雜。
牽一發(fā)而動(dòng)全身,終究有一天哪怕只做很小的改動(dòng),也將成為壓死駱駝的***一根稻草。
這次重構(gòu)的成果是代碼量由 43K 減少到 15K,擴(kuò)展新的接口能力不再需要修改已有代碼。我想,這或許就體現(xiàn)了碼農(nóng)和程序員的區(qū)別吧。
CT 是一個(gè)業(yè)務(wù)復(fù)雜度極高的行業(yè),要想從碼農(nóng)成長(zhǎng)為程序員,需要經(jīng)歷更多的煎熬,需要發(fā)揮更多的創(chuàng)造力,同時(shí)也意味著,我們比以往任何時(shí)候都需要越來(lái)越多的碼農(nóng)成長(zhǎng)為程序員。
既然我們選擇了編碼作為職業(yè),注定會(huì)經(jīng)歷各種心劫:枯燥、沮喪、迷茫,甚至浮躁……
然而無(wú)論處于哪種心境當(dāng)中,我相信,只要想起自己曾經(jīng)滿(mǎn)懷驚奇、興奮與真誠(chéng)敲下的那個(gè)程序——“Hello,World!”我們就會(huì)充滿(mǎn)了渴望和力量,因?yàn)槟鞘浅绦騿T最初的夢(mèng)想:改變世界。