剛寫了一百萬行代碼,現(xiàn)在迷之自信!
剛學(xué) C 語言的時(shí)候有種上下求索,欲上九天攬?jiān)碌暮狼閴阎荆Y(jié)果老師的冷水當(dāng)頭潑下:剛開始寫代碼會覺得很有意思,等寫了一百萬行后,其中滋味自己體會吧!
搞程序的累計(jì)寫到一百萬行代碼,到底是什么體驗(yàn)?zāi)?
如果一百萬是標(biāo)量的話,我來和大家研究一下這個(gè)數(shù)據(jù):
假設(shè)***的情況,一天 100 行高質(zhì)量代碼,一年 36500,100 / 3.65 = 27 年多。即便從 20 歲開始編碼,要到 50 歲左右方可完成。
但實(shí)際上關(guān)于平均代碼量的問題,即便把所有工作日都算上,大概也就是 20 - 30 行的樣子;如果僅討論集中的開發(fā)期,高峰也不會超過 200 行。
一百萬代碼就像找女朋友一樣不靠譜。。。。
看完之后小編就頭皮一陣發(fā)麻,讓我寫一萬行的代碼?!are you kidding me?我估計(jì)寫到 20 萬的時(shí)候就會突然有個(gè)疑問----“咦?我的頭發(fā)呢?”。
針對累計(jì)寫到一百萬行代碼,看看網(wǎng)友們怎么說:
網(wǎng)友 A
我寫兩千行代碼功能都得琢磨個(gè)兩三天,一百萬行真的是好多啊,最多了五年寫了也就 20 - 30 萬行代碼左右,還是有任務(wù)在身的情況被逼著寫的,讓我寫一百萬行代碼,恐怕這輩子得死在電腦前了...
網(wǎng)友 B
我是覺得如果說你一個(gè)工作寫了一百萬行代碼,那你在公司的地位應(yīng)該算資深員工了。如果你一個(gè)項(xiàng)目寫了一百萬行,那你肯定是參與了一個(gè)比較大的項(xiàng)目了。
如果你一個(gè)類寫了一百萬行,請問你用的是什么編輯器?如果你一個(gè)方法寫了一百萬行代碼的話,請問你有沒有被同事打死?
網(wǎng)友 C
據(jù)說要從初學(xué)者成長為程序員,那個(gè)得需要 10 萬行代碼的積累才可以呢。不過話說回來這樣說也很對,畢竟入門階段嘛,確實(shí)需要多打代碼才能積累經(jīng)驗(yàn)。
不過修煉一段時(shí)間之后,再注重代碼的量,那就不對了。這時(shí)候肯定是注重?cái)?shù)學(xué)還有算法思維,按這樣算的話,假如 20 萬是修煉門檻,真積累到了一百萬行代碼,肯定代碼質(zhì)量越來越高了,估計(jì)是某個(gè)領(lǐng)域的小專家也說不定。
至于真敲了一百萬行低質(zhì)量代碼,聽哥一句話,還是轉(zhuǎn)行吧。程序員不適合你這種鍥而不舍的精神。
網(wǎng)友 D
切,一群渣渣。給你們看看一張網(wǎng)圖就知道我連續(xù)熬夜寫幾千行代碼是什么狀態(tài)了。我感覺我快要窒息了,如果時(shí)間可以倒流,我希望我不做程序員!!!
網(wǎng)友 E
這簡直就是一個(gè)偽***啊,哪有什么人能打一百萬的代碼,從業(yè)五六年的程序員,如果按正常工作量的話一天也就一百多行,這五六年估計(jì)也就五六萬行吧。
如果是外包公司代碼量估計(jì)翻倍了,那就按五十萬行來算。但是誰會那么拼命去奮斗在一線一天一千行的去工作啊。寫五六十萬行肯定都轉(zhuǎn)行創(chuàng)業(yè)了,還繼續(xù)下去不猝死估計(jì)也脫一層皮了。
當(dāng)一個(gè)項(xiàng)目里的代碼超過一百萬行……
關(guān)于代碼的量,從初學(xué)者成長為程序員,需要代碼的積累,而以后數(shù)學(xué)功底和編程思維的深化更加重要。
一味的追求量并沒有任何實(shí)際意義,通常,越核心的部分代碼量越小,越容易寫大量代碼的,大概是沒什么技術(shù)含量的 UI、業(yè)務(wù)邏輯。而一些部分,用腳本或 DSL 實(shí)現(xiàn)可以更精簡。寫代碼和考試一樣,做題最多的不一定是成績***的。
怎么做高質(zhì)量的代碼
打好技術(shù)基礎(chǔ)
寫出高質(zhì)量代碼,并不是搭建空中樓閣,需要有一定的基礎(chǔ)。
這里我重點(diǎn)強(qiáng)調(diào)與代碼質(zhì)量密切相關(guān)的幾點(diǎn):
- 掌握好開發(fā)語言,比如做 Android 就必須對 Java 足夠熟悉,才能夠?qū)懗龈哔|(zhì)量 Java 代碼。
- 熟悉開發(fā)平臺,不同的開發(fā)平臺,有不同的 API,有不同的工作原理,同樣是 Java 代碼,在 PC 上寫與 Android 上寫很多地方不一樣。
要去熟悉 Android 編程的一些特性,iOS 編程的一些特性,了解清楚這些,才能寫出更加地道的代碼,充分發(fā)揮各自平臺的優(yōu)勢。
- 基礎(chǔ)的數(shù)據(jù)結(jié)構(gòu)與算法,掌握好這些在解決一些特定問題時(shí),可以以更加優(yōu)雅有效的方式處理。
- 基礎(chǔ)的設(shè)計(jì)原則,無需完全掌握 23 種經(jīng)典設(shè)計(jì)模式,只需要了解一些常用的設(shè)計(jì)原則即可,甚至你也可以只了解什么是低耦合,并在你的代碼中堅(jiān)持實(shí)踐,也能寫出很不錯(cuò)的代碼。
代碼標(biāo)準(zhǔn)
代碼標(biāo)準(zhǔn)在團(tuán)隊(duì)合作中尤為重要,誰也不希望一個(gè)項(xiàng)目中代碼風(fēng)格各異,看得讓人糟心,即便是個(gè)人開發(fā)者,現(xiàn)在也需要跟各種開源項(xiàng)目打交道。
標(biāo)準(zhǔn)怎么定是一個(gè)老生常談的話題,我經(jīng)歷過很多次的代碼標(biāo)準(zhǔn)討論會議,C++,C#,Java 等等,大家有時(shí)會堅(jiān)持自己的習(xí)慣不肯退讓。可現(xiàn)如今時(shí)代不一樣了,Google 等大廠已經(jīng)為我們制定好了各種標(biāo)準(zhǔn),就用這些業(yè)界標(biāo)準(zhǔn)吧。
想好再寫
除非你很清楚你要怎么做,否則我不建議邊做邊想。你真的搞清楚你要解決的問題是什么了嗎?你的方案是否能有效?有沒有更優(yōu)雅簡單的方案?
準(zhǔn)備怎么設(shè)計(jì)它,必要的情況下,需要有設(shè)計(jì)文檔,復(fù)雜一些的設(shè)計(jì)需要有同行評審,寫代碼其實(shí)是很簡單的事情,前提是你得先想清楚。
代碼重構(gòu)
重構(gòu)對于代碼質(zhì)量的重要性不言而喻,很難一次把代碼寫得讓自己滿意、無可挑剔。
技術(shù)債務(wù)
很多問題歸根結(jié)底都是技術(shù)債務(wù),這在一些大公司尤為常見。技術(shù)債務(wù)話題太大,但就代碼質(zhì)量而言,我只想提一下不要因?yàn)檫@些債是前人留下的你就不去管。
現(xiàn)實(shí)是沒有多少機(jī)會讓你從一個(gè)清爽清新的項(xiàng)目開始做起,你不得不去面對這些,你也沒法完全不跟這些所謂的爛代碼打交道。
當(dāng)你負(fù)責(zé)一個(gè)小模塊時(shí),除了把它做好之外,也要順便將與之糾纏在一起的技術(shù)債務(wù)還掉,因?yàn)檫@些債務(wù)最終將是整個(gè)團(tuán)隊(duì)來共同承擔(dān),任何一個(gè)人都別想獨(dú)善其身,如果你還對高質(zhì)量代碼有追求的話。
作為團(tuán)隊(duì)的技術(shù)負(fù)責(zé)人,也要頂住壓力,鼓勵(lì)大家勇于做出嘗試,引導(dǎo)大家不斷改進(jìn)代碼質(zhì)量,不要總是畏手畏腳,停滯不前,真要背鍋也得上,要有擔(dān)當(dāng)。
代碼審查
我曾經(jīng)聽過一些較高級別的技術(shù)分享,竟然還不時(shí)聽到一些呼吁大家要做代碼審查的主題。
我以為在這個(gè)級別的技術(shù)會議上,不應(yīng)再討論代碼審查有什么好,為什么要做代碼審查之類的問題。同時(shí)我接觸過相當(dāng)多所謂國內(nèi)一線互聯(lián)網(wǎng)公司,竟有許多是不做代碼審查的,這一度讓我頗為意外。
這里也不想多談如何做好代碼審查,只是就代碼質(zhì)量這點(diǎn),不客氣地說:沒有過代碼審查的經(jīng)歷往往很難寫出高質(zhì)量的代碼,尤其是在各種追求速度的糙快猛創(chuàng)業(yè)公司。
靜態(tài)檢查
很多代碼上的問題,都可以通過一些工具來找到,某些場景下,它比人要靠譜得多,至少不會出現(xiàn)某些細(xì)節(jié)上的遺漏,同時(shí)也能有效幫助大家減少代碼審查的工作量。
Android 開發(fā)中有 Lint,F(xiàn)ind bugs,PMD 等優(yōu)秀靜態(tài)檢查工具可用,通過改進(jìn)這些工具找出的問題,就能對語法的細(xì)節(jié),規(guī)范,編程的技巧有更多直觀了解。
建議***與持續(xù)集成(CI),代碼審查環(huán)境配套使用, 每次提交的代碼都能自動驗(yàn)證是否通過了工具的代碼檢查,通過才允許提交。
單元測試
Android 單元測試,一直備受爭議,主要還是原生的測試框架不夠方便,每跑一次用例需要在模擬器或者真機(jī)上運(yùn)行,效率太低,也不方便在 CI 環(huán)境下自動構(gòu)建單元測試,好在有 Robolectric,能幫我們解決部分問題。
單元測試的一個(gè)非常顯著的優(yōu)點(diǎn)是,當(dāng)你需要修改大量代碼時(shí),盡管放心修改,只需要保證單元測試用例通過即可,無需瞻前顧后。
充分自測
有一種說法:程序員最害怕的是他自己寫的代碼,尤其是準(zhǔn)備在眾人面前 show 自己的工作成果時(shí),因此在寫完代碼后,需要至少跑一遍基本的場景,一些簡單的異常流。
在把你的工作成果提交給測試或用戶前,充分自測是基本的職業(yè)素養(yǎng),不要總想著讓測試幫你找問題,隨便用幾下就 Crash 的東西,你好意思拿給別人嗎?
善用開源
并非開源的東西,質(zhì)量就高,但至少關(guān)注度較高,使用人數(shù)較多,口碑較好的開源項(xiàng)目,質(zhì)量是有一定保證的,這其中的道理很簡單。
即便存在一些問題,也可以通過提交反饋,不斷改進(jìn)。最重要的是,你自己花時(shí)間造的輪子,需要很多精力維護(hù),而充分利用開源項(xiàng)目,能幫助你節(jié)省很多時(shí)間,把精力專注在最需要你關(guān)心的問題上。
從另一個(gè)方面來說,開源項(xiàng)目中的一些知名項(xiàng)目,往往是領(lǐng)域內(nèi)的翹楚所寫,學(xué)習(xí)這些高手的代碼,能讓你了解到好的代碼應(yīng)該是怎樣的,培養(yǎng)出更靈敏的嗅覺,識別代碼中的各種味道。