1.在你責(zé)怪別人之前,先檢查自己的代碼
先想一想自己的假設(shè)和其他人的假設(shè)。來自不同供應(yīng)商的工具可能內(nèi)置不同的假設(shè),即便是相同的供應(yīng)商對于不同的工具,其假設(shè)也可能不同。
當(dāng)其他人正在報告一個你不能重復(fù)的問題的時候,去看看他們在做什么。他們可能會做一些你從來沒有想到過的事情,或者他們的做事順序與你的截然不同。
我個人的原則是,如果我有一個不能確定的錯誤,那么我會先考慮是不是編譯器的問題,然后再去檢查堆棧是否損壞。特別是當(dāng)添加跟蹤代碼會使得問題移動的話就更要這么做了。多線程問題是bug的另一個來源,有時候令人焦躁得簡直想拔光頭發(fā),或者直接想摔電腦。當(dāng)系統(tǒng)是多線程的時候,最好傾向于簡單的代碼。我們不能依賴調(diào)試和單元測試來發(fā)現(xiàn)任何一致性的bug,所以設(shè)計的簡單性是最重要的。
2.不斷學(xué)習(xí)
我們生活在一個有趣的時代。隨著軟件開發(fā)逐漸遍布全球各地,你會發(fā)現(xiàn)有很多人都可以干你的工作。所以你需要不斷學(xué)習(xí)以保持競爭力。否則,你就會落伍,停滯不前,直到有一天,這份工作不再需要你,或外包給一些更廉價的勞動力。
那么我們能做些什么?有些雇主很慷慨,會提供培訓(xùn)以拓寬你的技能。也有的人會說我沒時間或者沒這個資金去接受任何培訓(xùn)。所以,關(guān)鍵是要擺正心態(tài),學(xué)習(xí)是對自己的負(fù)責(zé)。
這里有一些學(xué)習(xí)的方法。而且許多資源都可以在互聯(lián)網(wǎng)上免費獲取:
閱讀書籍、雜志、博客、Twitter feeds和網(wǎng)站。如果你想更深入地了解對象,可以考慮添加到郵件列表或新聞組。
如果你真的很想學(xué)習(xí)某一種技術(shù),那么就親自動手寫代碼。盡量與導(dǎo)師一起工作。雖然你從任何人身上都可以學(xué)到一些東西,但是從那些比你更聰明或更有經(jīng)驗的人身上,你能學(xué)到的更多。如果你實在找不到這樣的良師益友,那么請繼續(xù)往下看。使用虛擬導(dǎo)師。在網(wǎng)絡(luò)上找你真正喜歡的作者和開發(fā)人員,閱讀他們寫的內(nèi)容,訂閱他們的博客。
了解你使用的框架和庫。知道事物的工作原理,有助于你更好地應(yīng)用它們。如果你使用的是開源資源,那么你真的很幸運。使用調(diào)試器單步執(zhí)行代碼,以查看內(nèi)部究竟是怎么回事。你也可以去看看那些確實比你聰明的人是如何編寫和審查代碼的。
當(dāng)你犯了錯誤,修復(fù)bug,或者遇到問題的時候,試著去真正理解發(fā)生了什么事情。很有可能其他人已經(jīng)遇到過同樣的問題,并且發(fā)布在了網(wǎng)上。谷歌搜索真的很有用。
學(xué)習(xí)東西還有一個好方法就是所謂的“教學(xué)相長”。當(dāng)別人在傾聽你的言語,并問你問題的同時,你也會學(xué)到東西??梢越⒂脩艚M或本地會議。
為自己感興趣語言和技術(shù)加入或啟動一個研究小組(模式社區(qū)),也可以創(chuàng)建本地的用戶組。
參加會議。如果去不了的話,也可以在網(wǎng)上看,許多會議會將其談話免費發(fā)布到網(wǎng)上。
曾經(jīng)對代碼庫運行過靜態(tài)分析工具,又或者查看下你的IDE警告?了解它們報告了什么,以及其原因。
我們都是普通人,我們需要時間和精力,以及不斷的努力才能促使自己不斷的學(xué)習(xí)。不過,你不必成天學(xué)習(xí)。只要你能有意識地花點時間去學(xué)習(xí)就可以了,哪怕每天一小時,有總比沒有好。人活著不是為了工作,你還應(yīng)該有自己的生活。
3.不要害怕破壞東西
每個具備行業(yè)經(jīng)驗的程序員肯定參與過代碼庫岌岌可危的項目。系統(tǒng)很糟糕,并且改變這邊總是會破壞另一邊不相關(guān)的功能。每次添加模塊,程序員只能想著盡可能少地改變代碼,每次發(fā)布都膽戰(zhàn)心驚。這座軟件的摩天大樓隨時有坍塌的可能。之所以改動代碼會如此傷腦筋是因為系統(tǒng)太糟糕了。但是即使你知道系統(tǒng)出了問題,卻又因為投鼠忌器,而不得不聽之任之。
不要害怕你的代碼。沒有人會在乎當(dāng)你搗鼓代碼的時候有沒有暫時破壞了什么東西。只要你做的改變不會讓項目重新回到開始狀態(tài),就不會令人崩潰。投入時間重構(gòu),能讓你受益于項目整個生命周期。這樣做還有一個額外的好處是,由于你有過這種處理病危系統(tǒng)的經(jīng)驗,所以你對它應(yīng)該如何工作非常內(nèi)行。要善于應(yīng)用這些知識,千萬不要反感這些寶貴的財富。重新定義內(nèi)部接口,重構(gòu)模塊,重構(gòu)復(fù)制粘貼代碼,并通過減少依賴來簡化設(shè)計。你可以通過消除特殊情況顯著降低代碼的復(fù)雜性,因為特殊情況往往是因為錯誤的耦合特點導(dǎo)致的。慢慢地從舊結(jié)構(gòu)過渡到新結(jié)構(gòu),測試一下同行。
4.專業(yè)程序員
專業(yè)程序員的一個最重要的特點是有責(zé)任心。專業(yè)程序員會為他們的職業(yè)生涯、預(yù)算、日程安排承諾、錯誤、技能技巧負(fù)責(zé)。一個專業(yè)的程序員不會將責(zé)任推卸給別人。
如果你是專業(yè)的,那么你就需要為自己的職業(yè)生涯負(fù)責(zé)。你有責(zé)任去閱讀和學(xué)習(xí)。你有責(zé)任去時刻關(guān)注最新的產(chǎn)業(yè)和技術(shù)。但是許多程序員覺得這應(yīng)該是他們雇主的工作。NO,大錯特錯。想一想醫(yī)生,想一想律師,他們都是靠自己來培養(yǎng)和訓(xùn)練自己的。他們的下班時間多用在了閱讀雜志報刊上。他們時刻關(guān)注著最新的資訊動態(tài)。所以,我們也應(yīng)該如此。
專業(yè)程序員會為他們編寫的代碼負(fù)責(zé)。除非他們知道這些代碼是有效的,否則就不會發(fā)布代碼。現(xiàn)在,好好思考這個問題:如果是你,你會不會在不透徹了解代碼的情況下就直接發(fā)布代碼?專業(yè)程序員不希望QA找到任何bug,因為這些代碼都是經(jīng)過他測試之后才發(fā)布的。當(dāng)然,QA依然會發(fā)現(xiàn)一些問題,因為沒有一個人是完美的。但作為專業(yè)程序員,我們的態(tài)度應(yīng)該是讓QA找不到任何缺陷。
專業(yè)程序員也是好的團隊成員。他們負(fù)責(zé)地對待整個團隊的輸出,而不是只顧自己的工作。他們樂于助人,善于向彼此學(xué)習(xí),在需要的時候甚至?xí)αο嘀?,為了項目前仆后繼。
5.充分利用代碼分析工具
測試的價值是編程早期階段就灌輸給軟件開發(fā)者的一個理念。近年來,單元測試,測試驅(qū)動開發(fā)和敏捷方法的興起,證實了我們開始注重于在開發(fā)周期的各個階段進行測試。但是,測試只是你可以用來提高代碼質(zhì)量的許多工具之一。
回過頭去看,當(dāng)C語言還是一個新事物的時候,CPU時間和任何類型的存儲都是非常寶貴的。第一個C語言編譯器注意到了這一點,所以選擇了通過去掉一些語義分析,來減少代碼之間的傳遞次數(shù)。這意味著,在編譯時,編譯器檢查到的可能只是可被檢測到的bug中的一小部分。為了彌補這個缺陷,Stephen Johnson寫了一個名為lint的工具——它將從你的代碼中刪除一些沒有價值的東西——從而實現(xiàn)一些已被它的兄弟C語言編譯器撤掉的靜態(tài)分析功能。然而,靜態(tài)分析工具卻因為可以給出大范圍的誤報警告和一些沒有必要遵循的靜態(tài)文體慣例的警告而倍受贊譽。
現(xiàn)在的語言、編譯器和靜態(tài)分析工具的設(shè)計和以前已經(jīng)大不相同。由于內(nèi)存和CPU時間變得相對比較便宜,因此負(fù)擔(dān)得起編譯器檢查更多的錯誤。幾乎每一種語言都擁有至少一個工具,用來檢查風(fēng)格指南的違規(guī)行為、常見問題以及一些狡猾的有時候可能很難捕捉到的錯誤,如潛在取消引用空指針。更高級的工具,如C的Splint,以及Python的pylint,是可配置的,這意味著你可以通過命令行開關(guān)或在IDE中,使用配置文件來讓工具選擇放過其中的哪些錯誤和警告。Splint甚至還能讓你在注釋中注解你的代碼,以便于更好地提示你的程序是如何工作的。
6.關(guān)心代碼
優(yōu)秀程序員能寫出好代碼,這是毋庸置疑的。好的代碼并不是憑空而來的,也不能靠運氣然后恰巧讓你瞎貓碰到死老鼠。為了獲得良好的代碼,你必須努力的改進。過程是艱難的。但是如果你確實關(guān)心代碼的話,那么你一定能收獲好代碼。
僅靠技術(shù)并不能成就好的編程。我碰到過一些非常聰明的程序員,他們能夠產(chǎn)出令人印象深刻的算法,能夠熟記語言標(biāo)準(zhǔn),但卻寫出了最可怕的代碼。這種代碼,閱讀起來很痛苦,使用起來很痛苦,修改起來更是令人痛不欲生。我也碰到過一些非常謙遜的程序員,因為堅持簡單的代碼,所以寫出來的程序更優(yōu)雅,更易于表達他的意思,和他們工作非常愉快。
基于我多年的經(jīng)驗,我得出的結(jié)論是,差強人意的程序員和偉大的程序員之間的真正區(qū)別是:態(tài)度。好的編程在于專業(yè)的方法,以及一種竭盡全力希望寫出最好軟件的期望。
要成為一個優(yōu)秀的程序員,你必須對自己的代碼負(fù)責(zé),真正關(guān)心代碼——養(yǎng)成積極向上的心態(tài)。偉大的代碼是由大師精心雕琢的,而不是由那些馬虎的程序員胡亂寫出來的。