我和很多人交流過一個有趣的現(xiàn)象绒疗,那就是剛畢業(yè)到30歲這段時間,會覺得時間過得很慢骂澄,總覺得自己還很年輕吓蘑,但是一旦過了30歲,時間就如白駒過隙坟冲,一年又一年飛逝而過磨镶。
我自己也是,眼瞅著畢業(yè)快15年了健提,15年間從一個剛畢業(yè)的菜鳥琳猫,成長為技術(shù)骨干,做到架構(gòu)師的職位私痹,回頭看看沸移,當(dāng)年聽取親戚的一句話痪伦,誤入計算機行業(yè),看來并沒有走錯雹锣,編程雖然枯燥辛苦网沾,但是如果真的感興趣,你就能體會到其中的樂趣蕊爵,并且獲得可觀的回報辉哥。
好奇心
劉慈欣在《朝聞道》中描繪過這么一個情節(jié):在古老的非洲大陸上,有個原始人無意中抬頭仰望星空攒射,凝視的時間稍微長了一些醋旦,超過了外星人設(shè)置的閾值,立刻拉響了人類即將產(chǎn)生文明的警報会放。因為外星人認為饲齐,人類已經(jīng)產(chǎn)生了對宇宙的好奇心,文明的產(chǎn)生咧最,科技的發(fā)展不過是一瞬間的事情捂人。
確實是這樣,好奇心驅(qū)動人類不斷向前矢沿,在短短的幾千年(相對于長達幾十萬年的原始時代)里就登上了月球滥搭,并且努力向其他行星拓展。
對于程序員來說也是類似捣鲸,如果你看到新技術(shù)瑟匆,新產(chǎn)品沒有像小孩看到新玩具那樣兩眼放光,沒有想趕緊在自己電腦上玩玩的沖動栽惶,你就需要仔細考慮下是否真的對軟件開發(fā)有興趣愁溜?如果根本沒興趣,不要浪費時間外厂,還是趁早轉(zhuǎn)行冕象,有更多有前(錢)途的職業(yè)在等著你。
沒有好奇心酣衷,就不愿意追本溯源交惯,追求技術(shù)的本質(zhì)。
沒有好奇心穿仪,就難于靜下心來席爽,耐得住寂寞,遠離浮躁和代碼奮斗啊片,更難于跨過這個苦逼行業(yè)帶來的種種挑戰(zhàn)只锻,走到架構(gòu)師這個位置了。
沒有好奇心紫谷,就不愿意學(xué)習(xí)新技術(shù)齐饮,一個架構(gòu)師捐寥,如果沒有對技術(shù)的敏感度和前瞻性,一直抱著一套技術(shù)架構(gòu)不變祖驱,估計很快會被淘汰握恳。
當(dāng)然自制力強大的人除外,但話說回來捺僻,靠著自制力讓自己做自己不喜歡的事情乡洼,豈不非常痛苦?
我在上公司的一個關(guān)于Leader的培訓(xùn)課的時候匕坯,老師一直在說Passion(激情)束昵,Passion,Passion葛峻,但我一直覺得沒有好奇心锹雏,沒有興趣,怎么會產(chǎn)生Passion呢术奖?
所以礁遵,對技術(shù)的好奇心/興趣,是一切的基礎(chǔ)腰耙。
養(yǎng)成計算機的思維方式
之前在“碼農(nóng)翻身”公共號發(fā)過一篇文章榛丢,叫《學(xué)會編程铲球,而不是學(xué)會Java》說的就是要能夠以計算機的方式去思考挺庞。
現(xiàn)在的計算機還很“弱智”,你不能這么說:『電腦稼病,我要創(chuàng)建一個像Java的ArrayList類似的類选侨,有個get、add然走、remove方法援制,還有這個ArrayList的容量不是固定的,能夠自增長芍瑞,快點給我寫出來晨仑!』
現(xiàn)在的電腦當(dāng)然寫不出來。
相反你只能用計算機能理解的方式拆檬,用非常非常低級的計算機語言去告訴它做事情:創(chuàng)建一個類洪己,分配一個固定大小的數(shù)組用來存放數(shù)據(jù),用一個數(shù)(size)來記錄數(shù)組里存了多少數(shù)據(jù)竟贯。如果數(shù)組滿了答捕,就需要增大數(shù)組,并且把數(shù)據(jù)從老數(shù)組復(fù)制到新數(shù)組屑那。
這里邊有很多很多的煩人的細節(jié)需要你去處理拱镐,一不留神就會出錯---計算機編程就是這樣艘款。
養(yǎng)成計算機的思維方式,流暢的把人類語言的需求轉(zhuǎn)化成計算機語言沃琅,這是程序員的基本功哗咆。
很多人會語法,也懂框架益眉,但是在基本功上卻不過關(guān)岳枷,只能在初級程序員上踏步。
這個基本功的訓(xùn)練就是數(shù)據(jù)結(jié)構(gòu)和算法呜叫,我的經(jīng)驗是多做習(xí)題(大學(xué)時我把數(shù)據(jù)結(jié)構(gòu)后面的習(xí)題都做了一遍)空繁,讓這個思維在腦子里固化,以后的編程就可以信手拈來了朱庆。
扎實基礎(chǔ)盛泡,融會貫通
我很久之前參與過一點開源軟件的開發(fā),有幸看到了一個老程序員的簡歷娱颊,讓我震驚的是他竟然在Altair這個最早的電腦上編過程序傲诵。
沒錯,Altair就是那個連顯示器和鍵盤都沒有箱硕,靠撥動開關(guān)來輸入拴竹,靠指示燈來輸出的所謂“個人電腦”,比爾蓋茨和保羅艾倫在上面寫了一個Baisc的解釋器剧罩,從此開始微軟之路栓拜。
如果有了在這樣的機器上編程的經(jīng)歷,我相信這些老程序員對硬件惠昔,驅(qū)動润绵,操作系統(tǒng)界牡,應(yīng)用軟件的理解要遠遠超過我們現(xiàn)在這些人淤齐。
我之前要寫文章遇到了一個問題:一個進程要讀取文件瞒津,在底層用的是DMA的方式,DMA完成文件讀取以后要通過中斷讓CPU去處理来氧,但是CPU和中斷處理程序根本不知道進程的ID诫给,它怎么去和進行關(guān)聯(lián),如何去喚醒那個等待的進程啦扬?這個問題讓我意識到其實我對計算機的基礎(chǔ)也并沒有融匯貫通中狂。
我們大學(xué)里都學(xué)過計算機組成原理、操作系統(tǒng)考传、編譯原理吃型、計算機網(wǎng)絡(luò)、數(shù)據(jù)庫僚楞、匯編語言勤晚,能不能把這些知識融會貫通枉层,打通任督二脈,在我們的腦海里建立一個計算機運算的圖景赐写?
把這些知識融為一體鸟蜡,我相信能超越絕大多數(shù)程序員。
現(xiàn)在的軟件開發(fā)封裝的層次已經(jīng)非常高了挺邀,只要學(xué)會Java就能做一個編程工作了揉忘,隨著你做的越來越深,越來越專端铛,這些基礎(chǔ)的問題就會浮現(xiàn)出來泣矛。
更重要的是,計算機軟硬件的基本思想在這幾十年里其實變化不大禾蚕,例如緩存您朽,增加抽象層等,有了這么基本的思想的武裝换淆,去學(xué)習(xí)新的東西不但學(xué)的快哗总,理解的會更透徹。
要透徹地理解一個技術(shù)的本質(zhì)
先舉個Ant中的例子倍试,大部分人學(xué)習(xí)Ant只是學(xué)會怎么使用讯屈,認識到Ant提供了很多內(nèi)置的task來幫助我們方便的完成自動化的構(gòu)建,例如命令县习。
很少人會思考為什么Ant的task是以XML來描述的涮母?為什么Ant不提供一套Java類庫/API來讓程序員用,那樣不是更自然嗎准颓?
這其中的一個重要原因就是XML可以自定義標簽哈蝇,所以表達力無與倫比棺妓;如果用java攘已,它的語法不允許自定義一個像copy、fileset這樣的關(guān)鍵字怜跑,只能定義一些類來模擬這些Copy样勃、Fileset,就沒有這么簡單明了性芬,不信你嘗試一下峡眶。
Ant給我們的重要啟示就是,用XML來描述任務(wù)植锉,能極大的擴展語言的能力辫樱。但是Ant的問題就是需要程序員處理太多的細節(jié),指定源代碼路徑俊庇,指定編譯文件的路徑狮暑,指定資源文件的路徑鸡挠,指定需要的jar包及其位置,很煩心搬男。
于是Maven出來使用“約定優(yōu)于配置”的方式解決了Ant的問題拣展。
理解了技術(shù)的本質(zhì)以后就能夠觸類旁通,就能夠快速學(xué)習(xí)缔逛,這在技術(shù)更新很快的軟件行業(yè)尤為重要备埃。
作為一個程序員,我們在工作的時候褐奴,關(guān)于一個技術(shù)點的了解按脚,不單單要做到知其然,還要知其所以然敦冬,甚至知其所必然乘寒,在這里也給大家推薦一個交流群:650385180里面會分享一些資深架構(gòu)師錄制的視頻錄像:有Spring,MyBatis匪补,Netty源碼分析伞辛,高并發(fā)、高性能夯缺、分布式蚤氏、微服務(wù)架構(gòu)的原理,JVM性能優(yōu)化這些成為架構(gòu)師必備的知識體系踊兜。還能領(lǐng)取免費的學(xué)習(xí)資源竿滨,相信對于已經(jīng)工作和遇到技術(shù)瓶頸的碼友,在這個群里會有你需要的內(nèi)容捏境。
只是學(xué)會使用是不行的于游,不但要知道how,還要知道why垫言。停下來贰剥,思考,才是進步的本質(zhì)筷频。
要能寫漂亮的代碼
架構(gòu)師不是高高在上蚌成,脫離代碼只說不做的人。架構(gòu)師首先是一個優(yōu)秀的程序員凛捏,要能夠編寫項目或產(chǎn)品中的核心功能担忧,隨時能夠卷起袖子去解決項目中的問題。
代碼寫的不漂亮怎么能拿得出手坯癣?怎么能夠服人瓶盛?所謂漂亮代碼不僅僅是清晰、易懂、優(yōu)雅惩猫,更要實現(xiàn)功能窒所,沒有Bug或者極少Bug。其實如果代碼簡單優(yōu)雅帆锋,一般沒什么問題吵取。
寫出漂亮代碼并不容易,需要思路清晰锯厢,有良好的編程基礎(chǔ)皮官,有優(yōu)秀的抽象能力,以及對一門語言的熟練掌握实辑。
抽象的能力
抽象思考的能力怎么強調(diào)都不為過捺氢。
現(xiàn)實的需求紛繁復(fù)雜,如果架構(gòu)師不能夠把這些亂無頭緒的需求抽象成一些“概念”剪撬,在概念的層次進行思考摄乒,系統(tǒng)根本就無法設(shè)計。
但是抽象出概念以后還不夠残黑,還要看看這個概念是不是正交的馍佑,能不能獨立變化,如果不能梨水,考慮下新的概念抽象拭荤。
“正交”講的是線性無關(guān),非常重要疫诽,就像一個點(x,y)舅世,在x軸的變化不會影響y,y軸的變化不會影響x奇徒,這就是正交雏亚。
“正交”威力巨大,(x,y)可以表達二維平面的所有的點摩钙,如果增加一個z軸罢低,不但能表達三維空間中所有的點,并且每個軸都可以獨立變化腺律。
如果能做出正交的設(shè)計奕短,這個系統(tǒng)的開發(fā)和維護會非常舒服,以為可以放心大膽的修改其中一個方面兒不會影響其他匀钧。
設(shè)計模式一直強調(diào)的『發(fā)現(xiàn)變化并且封裝變化』其實就是這個意思。抽象能力的訓(xùn)練沒有捷徑谬返,就是經(jīng)驗的積累之斯,勤于思考和學(xué)習(xí)。例如:學(xué)習(xí)Android的程序員可以思考下Android是怎么對未知的遣铝,紛繁復(fù)雜的應(yīng)用程序進行抽象的佑刷?為什么有Activity莉擒、Service、BroadcastReceiver瘫絮、ContentProvider這四大組件涨冀?
技術(shù)領(lǐng)導(dǎo)力
我在IBM學(xué)到的重要一課就是:要用技術(shù)的影響力來領(lǐng)導(dǎo)人,而不是威權(quán)和職位麦萤。
換句大白話來說鹿鳖,就是要能讓技術(shù)人員服你。有了技術(shù)影響力壮莹,你在團隊發(fā)出的聲音才會被傾聽翅帜,被尊重。
但是影響力不是很快就建成的命满,這是個漫長的過程:你解決了一個技術(shù)難題涝滴,你提出的方案被證明可行....
這樣的事情會一點一滴的積累起你在別人心目中的形象,建立你的個人品牌胶台,最終大家會給你貼上一個標簽:【大偶叽】