點(diǎn)擊上方“大魚機(jī)器人”,選擇
置頂或星標(biāo)公眾號(hào)
回顧十年之前,有一些事情,我希望當(dāng)初剛?cè)胄挟?dāng)程序員的我就能明白,并盡早養(yǎng)成這些習(xí)慣。它們可以幫助我更快、更專注地成長(zhǎng)。以下是我的一些建議,給當(dāng)年剛找到第一份程序員工作的我。
1每年花時(shí)間讀兩本關(guān)于軟件工程的書??
我每次花時(shí)間緩慢而認(rèn)真地閱讀別人推薦的軟件工程書籍時(shí),自身都會(huì)得到提升。所謂認(rèn)真閱讀,我的意思是要做筆記、與他人交談、寫寫畫畫、動(dòng)手嘗試、回過(guò)頭來(lái)重新閱讀。
我希望我在成為開(kāi)發(fā)人員的頭幾年就閱讀與軟件相關(guān)的書籍。 但我是在從業(yè)第 5 年左右才開(kāi)始這樣做的。諸如《C#深入》,《簡(jiǎn)潔代碼》和《Javascript:The Good Parts》之類的書都幫助我提升了技術(shù)水平。我并不是在推薦具體的書名——不管怎么說(shuō),其中有些都已經(jīng)過(guò)時(shí)了。我的建議是尋找比你現(xiàn)有知識(shí)更深入的書籍,可以是關(guān)于特定技術(shù)或關(guān)于軟件工程實(shí)踐的著作。
看這些書時(shí)我不會(huì)一目十行。實(shí)際上,我看得很慢。我通常每次坐下來(lái)只讀一兩章??吹臅r(shí)候,我會(huì)做筆記或把重點(diǎn)劃出來(lái);看完后,我會(huì)回顧并經(jīng)常與他人討論。我也開(kāi)始寫一些書評(píng)放在自己的個(gè)人博客:
https://blog.pragmaticengineer.com/my-reading-list/
主要是反思我學(xué)到的東西。過(guò)去幾年,我養(yǎng)成了這些習(xí)慣。這些習(xí)慣幫助我以技術(shù)經(jīng)理的身份迅速成長(zhǎng):它們對(duì)工程師來(lái)說(shuō)也非常有益。想找推薦書單嗎?這里是我已經(jīng)看過(guò)的和正在看的 書籍清單。
為什么書籍要好過(guò)博文、視頻或演講?其實(shí)我認(rèn)為書籍比其他加起來(lái)都要好。無(wú)論什么樣的主題內(nèi)容,與書籍相比,其他的格式都會(huì)流于表面。書籍里的知識(shí)更深入,而且組織良好。像本文這樣的帖子,我只需要花費(fèi)幾個(gè)小時(shí)來(lái)寫,但是我花費(fèi)在 我寫的這本關(guān)于軟件工程師成長(zhǎng)的書籍上 已經(jīng)將近一年。我認(rèn)為讀書可以更緩慢但深入地消化知識(shí)。
不要太貪心:每六個(gè)月讀完一本書已經(jīng)很棒了。挑選一本好書,多花一些時(shí)間好好閱讀。在讀了一兩本書之后,我還建議你閱讀《如何讀一本書:智能閱讀的經(jīng)典指南》一書,強(qiáng)烈推薦。
2精研你工作中主打的編程語(yǔ)言,學(xué)到底層??
我剛開(kāi)始時(shí)主要用 PHP,兼寫一點(diǎn)初級(jí) JavaScript。我在大學(xué)里學(xué)過(guò) C 和 C ++,都不喜歡。我的第一份全職工作用的是 C#。我了解很多種語(yǔ)言,但是沒(méi)有一種語(yǔ)言學(xué)得非常好。
兩年后,我開(kāi)始遇到一些麻煩,在調(diào)試 C#代碼時(shí)不得不找高級(jí)開(kāi)發(fā)人員幫忙。其中一個(gè)總是幫我調(diào)試程序的高級(jí)工程師,他似乎非常了解這種語(yǔ)言,他向我推薦了一本書《C#深度學(xué)習(xí)》讓我去看。然后我看了。我一路學(xué)到線程、垃圾回收和泛型的工作方式,這些都是底層知識(shí)。我花了數(shù)不清的時(shí)間去了解協(xié)方差(covariance)、逆方差(contravariance)和其他艱深的主題。
精研我工作中主打的語(yǔ)言是我做出的最佳決定之一。 在我的第一份工作中,這種研究只是無(wú)意為之的,并且還得靠那位高級(jí)工程師指點(diǎn);但是,這些知識(shí)在工作中,以及面試其他工作時(shí)都成了一種優(yōu)勢(shì)。在我職業(yè)生涯的后期,我有意深入研究新的語(yǔ)言和框架。我是作為 C # 程序員加入 Skype 的,但是,我們需要改用 JavaScript 和 WinJS。因此,我又深入學(xué)習(xí)了 JS,并掌握了 WinJS,以至于我可以 在 Pluralsight 上開(kāi)課。
你懂的語(yǔ)言越多,就越了解它們各自的長(zhǎng)處和短處。 當(dāng)我轉(zhuǎn)移到 iOS 時(shí),我已經(jīng)精通好幾種語(yǔ)言。Swift 出現(xiàn)時(shí),我簡(jiǎn)單關(guān)注并參與了語(yǔ)言討論,并 建議添加讀寫反射這項(xiàng)能力 到 swift 的未來(lái)規(guī)劃中。了解了該語(yǔ)言的特性后,就可以更容易地找出讓我的團(tuán)隊(duì) 從 Objective-C 遷移到 Swift 的最佳策略。而且,你知道的語(yǔ)言越多,就越容易掌握新的語(yǔ)言——并且在需要時(shí)更輕松地深入學(xué)習(xí)。
我覺(jué)得最近結(jié)對(duì)編程已經(jīng)過(guò)時(shí)了。當(dāng)年我們開(kāi)始時(shí),長(zhǎng)期結(jié)對(duì)的極限編程、測(cè)試驅(qū)動(dòng)開(kāi)發(fā)和 mob 編程都很受歡迎。與人結(jié)對(duì)之后,我獲得了職業(yè)生涯中一些最大的躍升。這些躍升比讀書更重要。
我曾與一位開(kāi)發(fā)人員有過(guò)一次難忘的結(jié)對(duì)編程經(jīng)歷。他對(duì)包括我在內(nèi)的所有人都進(jìn)行了嚴(yán)格的代碼審查。有一天我受夠了代碼審查工具上的評(píng)論,決定不再在上面答復(fù),而是坐在這些評(píng)論者旁邊,要求他們當(dāng)面向我說(shuō)明他們的評(píng)論。我最終學(xué)到了很多東西——同時(shí)還告訴他們,我認(rèn)為他們的評(píng)論不公平。他們注意到了這點(diǎn),建議我每當(dāng)有這種情況時(shí)就結(jié)對(duì)編程。然后我就去做了。這位開(kāi)發(fā)人員對(duì)性能有所了解,我通過(guò)跟他結(jié)對(duì)編程,了解到了潛在的性能瓶頸的來(lái)龍去脈——然后我教給他們有關(guān)可維護(hù)性方面的知識(shí)作為回報(bào)。
與另一位工程師進(jìn)行測(cè)試驅(qū)動(dòng)開(kāi)發(fā)經(jīng)歷,是我在結(jié)對(duì)編程中的另一個(gè)美好回憶。我們輪流編寫代碼和測(cè)試代碼。我們做了兩天,實(shí)現(xiàn)了系統(tǒng)中一個(gè)棘手的部分。那次經(jīng)歷實(shí)在令我大開(kāi)眼界。我們?cè)隍?yàn)證所有邊界值的過(guò)程中,甚至反過(guò)來(lái)完全改變了實(shí)現(xiàn)方法。我們還與該開(kāi)發(fā)商建立了牢固的紐帶并持續(xù)了數(shù)月之久。
4編寫單元測(cè)試用例,并在持續(xù)集成中運(yùn)行??
高級(jí)工程師們經(jīng)常談?wù)搯卧獪y(cè)試的重要性。但是單元測(cè)試似乎太違反直覺(jué)了:為什么要花更多的時(shí)間編寫看起來(lái)很簡(jiǎn)單的測(cè)試?這是我在某段時(shí)間里對(duì)單元測(cè)試的看法。
為了領(lǐng)略單元測(cè)試的價(jià)值,你需要擁有“啊哈!”時(shí)刻——當(dāng)你編寫的單元測(cè)試為你節(jié)省了一天的時(shí)間,那就是“啊哈!”時(shí)刻。在到達(dá)這一步之前,你需要腳踏實(shí)地,好好編寫這些測(cè)試,并使它們?cè)诔掷m(xù)集成中運(yùn)行。而且,你可能需要持續(xù)做上幾個(gè)月,才會(huì)得到一個(gè)“啊哈!”時(shí)刻。
我有兩個(gè)這樣的時(shí)刻。第一個(gè)發(fā)生在我為一個(gè)小型在線賭場(chǎng)構(gòu)建后端引擎(作為輔助項(xiàng)目)時(shí)。該 API 正在管理真金白銀,我因?yàn)楹ε路稿e(cuò)誤,所以用單元測(cè)試覆蓋了所有代碼。該項(xiàng)目交付比我預(yù)想要晚——部分原因歸咎于測(cè)試,它們耗費(fèi)了很多時(shí)間。但是這樣做是正確的。我在合同結(jié)束時(shí)將項(xiàng)目移交給了客戶,兩年后,他們告訴我,這些測(cè)試多次挽救了團(tuán)隊(duì)——如果不是因?yàn)闇y(cè)試失敗,代碼漏洞將會(huì)擴(kuò)散到生產(chǎn)環(huán)境中。
我的另一個(gè)“啊哈”時(shí)刻是在 Web 上構(gòu)建 Skype。我們?cè)?web.skype.com 上給 Google Hangouts 創(chuàng)造了一個(gè)新的競(jìng)爭(zhēng)對(duì)手。我們團(tuán)隊(duì)是一支強(qiáng)大的團(tuán)隊(duì),擁有完整的單元覆蓋范圍和嚴(yán)格的集成測(cè)試。進(jìn)入項(xiàng)目三個(gè)月后,工程師決定重構(gòu)整個(gè)項(xiàng)目的結(jié)構(gòu)。這是非常冒險(xiǎn)的重構(gòu),我們所有人都投票反對(duì)這樣做。
那位工程師指出,基于現(xiàn)有的測(cè)試覆蓋率,這次重構(gòu)應(yīng)該是小菜一碟,只要測(cè)試通過(guò),重構(gòu)就沒(méi)問(wèn)題。我對(duì)此表示懷疑。但這正是測(cè)試用例的用處。經(jīng)過(guò)為期一周的重構(gòu),他推動(dòng)了一次巨大的變革……一切都沒(méi)有中斷,當(dāng)時(shí)沒(méi)有,之后也沒(méi)有。所有測(cè)試均通過(guò)。就在那刻,我意識(shí)到了一套強(qiáng)大的測(cè)試用例所能提供的安全保障,以及它能夠讓我們不害怕重構(gòu)的事實(shí)。
5養(yǎng)成重構(gòu)習(xí)慣并掌握重構(gòu)工具??
多年來(lái),當(dāng)我與團(tuán)隊(duì)合作時(shí),我傾向于在代碼庫(kù)中進(jìn)行盡可能小的更改。對(duì)于我自己的個(gè)人項(xiàng)目,我進(jìn)行了大量的重構(gòu)——但是我從來(lái)不在我不完全掌控的代碼庫(kù)上做這種事情。
然后,我在 Skype 遇到了一位工程師,他會(huì)不斷進(jìn)行小型或大型重構(gòu)。他們都有道理,并且代碼總是變得更好。而且他們從不搞亂事情。他們是如何做到的呢?
當(dāng)我與他們結(jié)對(duì)編程時(shí),發(fā)現(xiàn)他們非常了解自己的 IDE,并添加了用于重構(gòu)的插件。提取方法、改變量名、提取成常量..……他們只需要花一秒鐘。
我意識(shí)到,我害怕重構(gòu),既錯(cuò)過(guò)了實(shí)踐,又錯(cuò)過(guò)了能幫助我重構(gòu)的工具。 于是當(dāng)我開(kāi)始養(yǎng)成每周重構(gòu)一次的習(xí)慣時(shí),我在這兩個(gè)方面都提升了。這個(gè)習(xí)慣后來(lái)對(duì)我很有幫助——我多么希望自己在很多年前就開(kāi)始這么做啊。
6學(xué)習(xí)良好的軟件工程經(jīng)驗(yàn),這使我獲益良多??
在我剛開(kāi)始做軟件工程師的時(shí)候,我曾經(jīng)被高級(jí)工程師唬到了。他們看出了我沒(méi)看出來(lái)的錯(cuò)誤,他們知道我不知道的答案。我當(dāng)時(shí)以為他們比我更聰明,并且接受了這一切。
現(xiàn)在,我已經(jīng)與許多著名的軟件工程師緊密合作過(guò),并擔(dān)任了另外幾位的導(dǎo)師,我發(fā)現(xiàn)沒(méi)有那么唬人。最好的軟件工程師會(huì)把學(xué)到的知識(shí)和實(shí)際經(jīng)驗(yàn)結(jié)合在一起——知識(shí),你可以去學(xué);經(jīng)驗(yàn),你需要去實(shí)踐。
找機(jī)會(huì)在不同的技術(shù)棧、不同的領(lǐng)域和具有挑戰(zhàn)性的項(xiàng)目里工作。 我花了七八年的時(shí)間才達(dá)到我認(rèn)為的“高級(jí)”水平。我看到有些人加入了像 Uber 這種高成長(zhǎng)性的公司,三四年就達(dá)到了。這中間的區(qū)別是什么?這些人從事具有挑戰(zhàn)性的項(xiàng)目,力求跟上周圍其他人的步伐,并經(jīng)常在中途更換團(tuán)隊(duì),重新開(kāi)始。他們自愿參與新項(xiàng)目,并在團(tuán)隊(duì)中率先嘗試新技術(shù)。雖然我最終還是成為了這樣的人,但那是后來(lái)的事,不是在最初的幾年中。
學(xué)習(xí)某些東西,最好的方法是把它們教給別人。我是很偶然發(fā)現(xiàn)這一點(diǎn)的。在 2010 年,我開(kāi)始在.NET 和 Windows Phone 用戶組中 做演示。我的演講效果不佳,但是我僅在準(zhǔn)備階段就學(xué)到了很多東西。
現(xiàn)在,當(dāng)我想學(xué)好東西時(shí),就會(huì)報(bào)名參加了一次公開(kāi)討論。 加入 Uber 一年后,我提出做一個(gè)演講,介紹在 2017 年 Uber 如何大規(guī)模推出后端更改。當(dāng)時(shí),我還不完全了解我們是如何做到的——在那之前,我主要從事移動(dòng)開(kāi)發(fā),并管理一個(gè)移動(dòng)團(tuán)隊(duì)。通過(guò)演講,我別無(wú)選擇,只能學(xué)習(xí)所有細(xì)節(jié)。我這樣做的壓力很大:大約有 100 個(gè)本地開(kāi)發(fā)人員報(bào)名要來(lái)聽(tīng)我的演講。
許多其他人也說(shuō)這種方法很有效——Shawn“Swyx” Wang 是 #LearnInPublic approach 的杰出代表。他的成長(zhǎng)故事遠(yuǎn)比我的經(jīng)歷令人印象深刻:改行后在四年里做到 Netlify 和 AWS 的高級(jí)工程師職位,并 撰寫了一本 關(guān)于他學(xué)習(xí)經(jīng)歷的書。教別人你只會(huì)得到好處。你不僅可以通過(guò)教學(xué)來(lái)學(xué)到東西,而且還可以幫助和啟發(fā)他人。
而且我認(rèn)識(shí)的所有經(jīng)驗(yàn)豐富的模范開(kāi)發(fā)人員,都是合格的老師和導(dǎo)師。越早開(kāi)始回饋和教導(dǎo),就會(huì)越自然而然地成為這樣的開(kāi)發(fā)人員。
https://blog.pragmaticengineer.com/advice-to-myself-when-starting-as-a-software-developer/
|?整理文章為傳播相關(guān)技術(shù),版權(quán)歸原作者所有?|
|?如有侵權(quán),請(qǐng)聯(lián)系刪除?|
硬核妹子的創(chuàng)意設(shè)計(jì):舌頭控制器
只有6個(gè)引腳的單片機(jī),居然可以玩游戲。
若覺(jué)得文章不錯(cuò),轉(zhuǎn)發(fā)分享,也是我們繼續(xù)更新的動(dòng)力。
5T資源大放送!包括但不限于:C/C++,Linux,Python,Java,PHP,人工智能,PCB、FPGA、DSP、labview、單片機(jī)、等等!
在公眾號(hào)內(nèi)回復(fù)「更多資源」,即可免費(fèi)獲取,期待你的關(guān)注~
免責(zé)聲明:本文內(nèi)容由21ic獲得授權(quán)后發(fā)布,版權(quán)歸原作者所有,本平臺(tái)僅提供信息存儲(chǔ)服務(wù)。文章僅代表作者個(gè)人觀點(diǎn),不代表本平臺(tái)立場(chǎng),如有問(wèn)題,請(qǐng)聯(lián)系我們,謝謝!