六星源課堂:程序員成長(zhǎng)的6個(gè)壓箱底技巧,你get了嗎?

程序員成長(zhǎng)的6個(gè)壓箱底技巧,六星源課堂統(tǒng)統(tǒng)分享給大家!

1.在你責(zé)怪別人之前,先檢查自己的代碼
先想一想自己的假設(shè)和其他人的假設(shè)。來(lái)自不同供應(yīng)商的工具可能內(nèi)置不同的假設(shè),即便是相同的供應(yīng)商對(duì)于不同的工具,其假設(shè)也可能不同。
當(dāng)其他人正在報(bào)告一個(gè)你不能重復(fù)的問(wèn)題的時(shí)候,去看看他們?cè)谧鍪裁础K麄兛赡軙?huì)做一些你從來(lái)沒(méi)有想到過(guò)的事情,或者他們的做事順序與你的截然不同。
我個(gè)人的原則是,如果我有一個(gè)不能確定的錯(cuò)誤,那么我會(huì)先考慮是不是編譯器的問(wèn)題,然后再去檢查堆棧是否損壞。特別是當(dāng)添加跟蹤代碼會(huì)使得問(wèn)題移動(dòng)的話就更要這么做了。多線程問(wèn)題是bug的另一個(gè)來(lái)源,有時(shí)候令人焦躁得簡(jiǎn)直想拔光頭發(fā),或者直接想摔電腦。當(dāng)系統(tǒng)是多線程的時(shí)候,最好傾向于簡(jiǎn)單的代碼。我們不能依賴調(diào)試和單元測(cè)試來(lái)發(fā)現(xiàn)任何一致性的bug,所以設(shè)計(jì)的簡(jiǎn)單性是最重要的。
所以,在你不分青紅皂白地去責(zé)怪編譯器之前,先想一想福爾摩斯的這條建議,“一旦你排除了種種不可能,剩下的不管有多么難以置信,一定就是真相”。
2.不斷學(xué)習(xí)
我們生活在一個(gè)有趣的時(shí)代。隨著軟件開(kāi)發(fā)逐漸遍布全球各地,你會(huì)發(fā)現(xiàn)有很多人都可以干你的工作。所以你需要不斷學(xué)習(xí)以保持競(jìng)爭(zhēng)力。否則,你就會(huì)落伍,停滯不前,直到有一天,這份工作不再需要你,或外包給一些更廉價(jià)的勞動(dòng)力。
那么我們能做些什么?有些雇主很慷慨,會(huì)提供培訓(xùn)以拓寬你的技能。也有的人會(huì)說(shuō)我沒(méi)時(shí)間或者沒(méi)這個(gè)資金去接受任何培訓(xùn)。所以,關(guān)鍵是要擺正心態(tài),學(xué)習(xí)是對(duì)自己的負(fù)責(zé)。
這里有一些學(xué)習(xí)的方法。而且許多資源都可以在互聯(lián)網(wǎng)上免費(fèi)獲?。?/p>
閱讀書(shū)籍、雜志、博客、Twitter feeds和網(wǎng)站。如果你想更深入地了解對(duì)象,可以考慮添加到郵件列表或新聞組。如果你真的很想學(xué)習(xí)某一種技術(shù),那么就親自動(dòng)手寫(xiě)代碼。盡量與導(dǎo)師一起工作。雖然你從任何人身上都可以學(xué)到一些東西,但是從那些比你更聰明或更有經(jīng)驗(yàn)的人身上,你能學(xué)到的更多。如果你實(shí)在找不到這樣的良師益友,那么請(qǐng)繼續(xù)往下看。使用虛擬導(dǎo)師。在網(wǎng)絡(luò)上找你真正喜歡的作者和開(kāi)發(fā)人員,閱讀他們寫(xiě)的內(nèi)容。訂閱他們的博客。了解你使用的框架和庫(kù)。知道事物的工作原理,有助于你更好地應(yīng)用它們。如果你使用的是開(kāi)源資源,那么你真的很幸運(yùn)。使用調(diào)試器單步執(zhí)行代碼,以查看內(nèi)部究竟是怎么回事。你也可以去看看那些確實(shí)比你聰明的人是如何編寫(xiě)和審查代碼的。當(dāng)你犯了錯(cuò)誤,修復(fù)bug,或者遇到問(wèn)題的時(shí)候,試著去真正理解發(fā)生了什么事情。很有可能其他人已經(jīng)遇到過(guò)同樣的問(wèn)題,并且發(fā)布在了網(wǎng)上。谷歌搜索真的很有用。學(xué)習(xí)東西還有一個(gè)好方法就是所謂的“教學(xué)相長(zhǎng)”。當(dāng)別人在傾聽(tīng)你的言語(yǔ),并問(wèn)你問(wèn)題的同時(shí),你也會(huì)學(xué)到東西。可以建立用戶組或本地會(huì)議。為自己感興趣語(yǔ)言和技術(shù)加入或啟動(dòng)一個(gè)研究小組(模式社區(qū)),也可以創(chuàng)建本地的用戶組。參加會(huì)議。如果去不了的話,也可以在網(wǎng)上看,許多會(huì)議會(huì)將其談話免費(fèi)發(fā)布到網(wǎng)上。收聽(tīng)播客。曾經(jīng)對(duì)代碼庫(kù)運(yùn)行過(guò)靜態(tài)分析工具,又或者查看下你的IDE警告?了解它們報(bào)告了什么,以及其原因。
然如果你有《黑客帝國(guó)》中Neo那樣的超能力,自然這一切對(duì)你而言不過(guò)是小菜一碟。但很可惜,我們都是普通人,我們需要時(shí)間和精力,以及不斷的努力才能促使自己不斷的學(xué)習(xí)。不過(guò),你不必成天學(xué)習(xí)。只要你能有意識(shí)地花點(diǎn)時(shí)間去學(xué)習(xí)就可以了,哪怕每天一小時(shí),有總比沒(méi)有好。人活著不是為了工作,你還應(yīng)該有自己的生活。
3.不要害怕破壞東西
每個(gè)具備行業(yè)經(jīng)驗(yàn)的程序員肯定參與過(guò)代碼庫(kù)岌岌可危的項(xiàng)目。系統(tǒng)很糟糕,并且改變這邊總是會(huì)破壞另一邊不相關(guān)的功能。每次添加模塊,程序員只能想著盡可能少地改變代碼,每次發(fā)布都膽戰(zhàn)心驚。這座軟件的摩天大樓隨時(shí)有坍塌的可能。之所以改動(dòng)代碼會(huì)如此傷腦筋是因?yàn)橄到y(tǒng)太糟糕了。但是即使你知道系統(tǒng)出了問(wèn)題,卻又因?yàn)橥妒蠹善?,而不得不?tīng)之任之。任何一個(gè)外科醫(yī)生都懂得,傷口要想愈合就必須得切除腐肉。雖然手術(shù)會(huì)帶來(lái)痛苦,但絕對(duì)比任傷口發(fā)炎潰爛要好。
不要害怕你的代碼。沒(méi)有人會(huì)在乎當(dāng)你搗鼓代碼的時(shí)候有沒(méi)有暫時(shí)破壞了什么東西。只要你做的改變不會(huì)讓項(xiàng)目重新回到開(kāi)始狀態(tài),就不會(huì)令人崩潰。投入時(shí)間重構(gòu),能讓你受益于項(xiàng)目整個(gè)生命周期。這樣做還有一個(gè)額外的好處是,由于你有過(guò)這種處理病危系統(tǒng)的經(jīng)驗(yàn),所以你對(duì)它應(yīng)該如何工作非常內(nèi)行。要善于應(yīng)用這些知識(shí),千萬(wàn)不要反感這些寶貴的財(cái)富。重新定義內(nèi)部接口,重構(gòu)模塊,重構(gòu)復(fù)制粘貼代碼,并通過(guò)減少依賴來(lái)簡(jiǎn)化設(shè)計(jì)。你可以通過(guò)消除特殊情況顯著降低代碼的復(fù)雜性,因?yàn)樘厥馇闆r往往是因?yàn)殄e(cuò)誤的耦合特點(diǎn)導(dǎo)致的。慢慢地從舊結(jié)構(gòu)過(guò)渡到新結(jié)構(gòu),測(cè)試一路同行。如果你想要一下子完成一個(gè)大的重構(gòu),那么往往會(huì)因?yàn)楦鞣N頻出的問(wèn)題而考慮中途放棄。

4.專業(yè)程序員
專業(yè)程序員的一個(gè)最重要的特點(diǎn)是有責(zé)任心。專業(yè)程序員會(huì)為他們的職業(yè)生涯、預(yù)算、日程安排承諾、錯(cuò)誤、技能技巧負(fù)責(zé)。一個(gè)專業(yè)的程序員不會(huì)將責(zé)任推卸給別人。
如果你是專業(yè)的,那么你就需要為自己的職業(yè)生涯負(fù)責(zé)。你有責(zé)任去閱讀和學(xué)習(xí)。你有責(zé)任去時(shí)刻關(guān)注最新的產(chǎn)業(yè)和技術(shù)。但是許多程序員覺(jué)得這應(yīng)該是他們雇主的工作。NO,大錯(cuò)特錯(cuò)。想一想醫(yī)生?想一想律師?他們都是靠自己來(lái)培養(yǎng)和訓(xùn)練自己的。他們的下班時(shí)間多用在了閱讀雜志報(bào)刊上。他們時(shí)刻關(guān)注著最新的資訊動(dòng)態(tài)。所以,我們也應(yīng)該如此。你和你雇主之間的關(guān)系,已經(jīng)在雇用合同上作了詳細(xì)的說(shuō)明,簡(jiǎn)而言之就是:你的雇主承諾支付你薪酬,而你承諾做好工作。
專業(yè)程序員會(huì)為他們編寫(xiě)的代碼負(fù)責(zé)。除非他們知道這些代碼是有效的,否則就不會(huì)發(fā)布代碼?,F(xiàn)在,好好思考這個(gè)問(wèn)題:如果是你,你會(huì)不會(huì)在不透徹了解代碼的情況下就直接發(fā)布代碼?專業(yè)程序員不希望QA找到任何bug,因?yàn)檫@些代碼都是經(jīng)過(guò)他測(cè)試之后才發(fā)布的。當(dāng)然,QA依然會(huì)發(fā)現(xiàn)一些問(wèn)題,因?yàn)闆](méi)有一個(gè)人是完美的。但作為專業(yè)程序員,我們的態(tài)度應(yīng)該是讓QA找不到任何缺陷。
專業(yè)程序員也是好的團(tuán)隊(duì)成員。他們負(fù)責(zé)地對(duì)待整個(gè)團(tuán)隊(duì)的輸出,而不是只顧自己的工作。他們樂(lè)于助人,善于向彼此學(xué)習(xí),在需要的時(shí)候甚至?xí)αο嘀?,為了?xiàng)目前仆后繼。
5.充分利用代碼分析工具
測(cè)試的價(jià)值是編程早期階段就灌輸給軟件開(kāi)發(fā)者的一個(gè)理念。近年來(lái),單元測(cè)試,測(cè)試驅(qū)動(dòng)開(kāi)發(fā)和敏捷方法的興起,證實(shí)了我們開(kāi)始注重于在開(kāi)發(fā)周期的各個(gè)階段進(jìn)行測(cè)試。但是,測(cè)試只是你可以用來(lái)提高代碼質(zhì)量的許多工具之一。
回過(guò)頭去看,當(dāng)C語(yǔ)言還是一個(gè)新事物的時(shí)候,CPU時(shí)間和任何類型的存儲(chǔ)都是非常寶貴的。第一個(gè)C語(yǔ)言編譯器注意到了這一點(diǎn),所以選擇了通過(guò)去掉一些語(yǔ)義分析,來(lái)減少代碼之間的傳遞次數(shù)。這意味著,在編譯時(shí),編譯器檢查到的可能只是可被檢測(cè)到的bug中的一小部分。為了彌補(bǔ)這個(gè)缺陷,Stephen Johnson寫(xiě)了一個(gè)名為lint的工具——它將從你的代碼中刪除一些沒(méi)有價(jià)值的東西——從而實(shí)現(xiàn)一些已被它的兄弟C語(yǔ)言編譯器撤掉的靜態(tài)分析功能。然而,靜態(tài)分析工具卻因?yàn)榭梢越o出大范圍的誤報(bào)警告和一些沒(méi)有必要遵循的靜態(tài)文體慣例的警告而倍受贊譽(yù)。
現(xiàn)在的語(yǔ)言、編譯器和靜態(tài)分析工具的設(shè)計(jì)和以前已經(jīng)大不相同。由于內(nèi)存和CPU時(shí)間變得相對(duì)比較便宜,因此負(fù)擔(dān)得起編譯器檢查更多的錯(cuò)誤。幾乎每一種語(yǔ)言都擁有至少一個(gè)工具,用來(lái)檢查風(fēng)格指南的違規(guī)行為、常見(jiàn)問(wèn)題以及一些狡猾的有時(shí)候可能很難捕捉到的錯(cuò)誤,如潛在取消引用空指針。更高級(jí)的工具,如C的Splint,以及Python的pylint,是可配置的,這意味著你可以通過(guò)命令行開(kāi)關(guān)或在IDE中,使用配置文件來(lái)讓工具選擇放過(guò)其中的哪些錯(cuò)誤和警告。Splint甚至還能讓你在注釋中注解你的代碼,以便于更好地提示你的程序是如何工作的。

6.關(guān)心代碼
優(yōu)秀程序員能寫(xiě)出好代碼,這是毋庸置疑的。壞程序員……則不能(他們能寫(xiě)出好代碼,就不是壞程序員了,哈哈)。他們總是在生產(chǎn)其他人不得不消滅的怪獸。你的目標(biāo)是寫(xiě)出好代碼,對(duì)不?那么你應(yīng)該成為好程序員。
好的代碼并不是憑空而來(lái)的,也不能靠運(yùn)氣然后恰巧讓你瞎貓碰到死老鼠。為了獲得良好的代碼,你必須努力的改進(jìn)。過(guò)程是艱難的。但是如果你確實(shí)關(guān)心代碼的話,那么你一定能收獲好代碼。
僅靠技術(shù)并不能成就好的編程。我碰到過(guò)一些非常聰明的程序員,他們能夠產(chǎn)出令人印象深刻的算法,能夠熟記語(yǔ)言標(biāo)準(zhǔn),但卻寫(xiě)出了最可怕的代碼。這種代碼,閱讀起來(lái)很痛苦,使用起來(lái)很痛苦,修改起來(lái)更是令人痛不欲生。我也碰到過(guò)一些非常謙遜的程序員,因?yàn)閳?jiān)持簡(jiǎn)單的代碼,所以寫(xiě)出來(lái)的程序更優(yōu)雅,更易于表達(dá)他的意思,和他們工作非常愉快。
基于我多年的軟件生產(chǎn)經(jīng)驗(yàn),我得出的結(jié)論是,差強(qiáng)人意的程序員和偉大的程序員之間的真正區(qū)別是:態(tài)度。好的編程在于專業(yè)的方法,以及一種竭盡全力希望寫(xiě)出最好軟件的期望。
要成為一個(gè)優(yōu)秀的程序員,你必須對(duì)自己的代碼負(fù)責(zé),真正關(guān)心代碼——養(yǎng)成積極向上的心態(tài)。偉大的代碼是由大師精心雕琢的,而不是由那些馬虎的程序員胡亂寫(xiě)出來(lái)的。
以上就是本次分享的全部?jī)?nèi)容,想學(xué)習(xí)更多編程技巧,歡迎持續(xù)關(guān)注六星源課堂!