開發(fā)應(yīng)用程序是一個非常有壓力的工作。沒有人是完美的忿墅,因此在這個行業(yè)中扁藕,代碼中出現(xiàn)bug是相當(dāng)普遍的現(xiàn)象。面對bug球匕,一些程序員會生氣纹磺,會沮喪,會心煩意亂亮曹,甚至?xí)倚膯蕷猓硪恍┏绦騿T會依然保持冷靜沉著秘症。因此照卦,如何處理修復(fù)bug的過程也值得我們細細琢磨。
我想分享一些程序員修復(fù)他們的源代碼時所經(jīng)歷的想法乡摹。這是事情變得緊張時所觸發(fā)的輕松幽默役耕。通常說來,應(yīng)用程序終將可以工作聪廉,然后你也可以進入到下一個偉大的任務(wù)瞬痘。
我相信很多web開發(fā)人員和軟件工程師經(jīng)歷過這些艱辛故慈,然后在事后一笑而過。
1.“我不知道是要刪除還是要重寫它”
回顧從前老的源代碼框全,會有一種想要返工寫成較大塊集群的沖動和誘惑察绷。丑陋的邏輯語句,還有冗長的語法津辩,導(dǎo)致代碼非常難以閱讀拆撼!但話又說回來,如果代碼沒有壞掉的話喘沿,那就不要去修復(fù)它闸度。這種洶涌澎拜的斗爭是我經(jīng)常要面對的,而且顯然會困擾許多軟件開發(fā)人員蚜印。
2.“對于起始框架我應(yīng)該查看Github”
我想大多數(shù)開發(fā)人員都知道Github莺禁,上面每天都有數(shù)量驚人的開源項目發(fā)布。任何語言的程序員都可以通過互聯(lián)網(wǎng)借鑒現(xiàn)有項目窄赋,加入維基討論哟冬,或者創(chuàng)建自己的代碼倉庫。它是各種項目所需插件和模板的超棒資源寝凌。
3.“為什么這個腳本需要這么多庫柒傻?”
尤其是一些比較大眾化的語言,如Java和Objective-C较木,庫的數(shù)量可能變得異常兇猛红符。當(dāng)構(gòu)建一個需要大量基礎(chǔ)的框架時,所需的庫的數(shù)量就變得顯而易見得多伐债。即使是一些適用于JavaScript的插件预侯,也會額外需要無數(shù)的文件。有時峰锁,這會讓人覺得煩雜惱人——但至少是有用的萎馅!
4.“在互聯(lián)網(wǎng)的某個地方一定已經(jīng)有了解決方案『缃”
我面對棘手問題的第一反應(yīng)是上網(wǎng)查糜芳。程序員會將他們遇到的問題通過帖子發(fā)布到論壇上,然后這個問題最終得到解決并歸檔魄衅。谷歌搜索問題關(guān)鍵字的好幫手峭竣,可以指點你往正確的討論方向走。不幸的是晃虫,有的時候卻是因為手頭沒有特定問題的太多信息而找不著北皆撩。
5.“有沒有這個功能的插件?”
為什么要重新發(fā)明輪子哲银?插件是擴大任何程序或網(wǎng)站用戶界面的偉大資源扛吞。此外呻惕,它們還為開發(fā)人員提供了一些自定義和獨特的選項。萬一真的沒有可用插件的話滥比,沒什么不自己構(gòu)建一個呢亚脆?
6.“雖然網(wǎng)站可以工作,但我害怕IE瀏覽器守呜⌒退郑”
在Internet Explorer中渲染網(wǎng)頁的歷史充滿的艱辛考驗,是我們有目共睹或親身體驗過的查乒。從5.5版本升級到IE9-IE10弥喉,總是需要爭取到更高級瀏覽器的支持。web開發(fā)人員可能會害怕調(diào)試網(wǎng)頁玛迄,因為在IE6中打開頁面是一個渲染噩夢由境。值得慶幸的是,這樣的日子正在慢慢成為過去蓖议。
7.“對于邏輯表達式而言虏杰,這似乎并不怎么合乎邏輯±障海”
對于if / else循環(huán)纺阔,for循環(huán),while循環(huán)修然,do循環(huán)等等笛钝,都有邏輯表達式。當(dāng)瀏覽示例代碼時愕宋,我試圖指出我的邏輯是如何工作的玻靡。NOT運算符和比較標(biāo)記的數(shù)量又是如此之多。我經(jīng)持斜矗回過頭去更新我自己的邏輯以便于更好地適合未來的做法囤捻。
8.“我用30分鐘寫函數(shù),花2小時讓它工作邻寿⌒粒”
這難道不像我們自己的編程故事嗎?你正興致勃勃地在構(gòu)建著什么绣否,但是突然之間瘟则,函數(shù)輸出了一個致命的錯誤。所以枝秤,現(xiàn)在你必須回過頭去刪除一些代碼塊,以找出錯誤發(fā)生的行號慷嗜。當(dāng)你終于找到罪魁禍?zhǔn)椎淼⒔鉀Q它時丹壕,雖然有種精疲力竭的感覺,但也滿心安慰薇溃。
9.“在閱讀多篇博客文章之后菌赖,我意識到,我之前全都是錯的沐序×鹩茫”
我常常會一開始就根據(jù)自己的編程思想,一頭扎進去研究策幼,但是這可能會導(dǎo)致麻煩邑时,如果事情不像原先設(shè)想地那樣順利的話。已經(jīng)有很多次在我啟動一個項目之后特姐,陷入了困境晶丘,然后只好尋求博客和其他論文的支持。然后我發(fā)現(xiàn)我的整個方法實際上是錯誤的唐含,而且從頭來過更容易浅浮!如果我開始的時候能先做一番研究的話,從長遠來說捷枯,反而節(jié)省時間滚秩。
10.“Stack Overflow上和善的人或許愿意幫助我』蠢Γ”
我已經(jīng)數(shù)不清有多少次我通過Stack Overflow解決了難題郁油。社區(qū)里都是和善和聰明的人,他們非常愿意提供幫助争剿,如果你邁出第一步的話已艰。在所有的在線論壇中,Stack Overflow絕對是對軟件編程以及前端/后端web開發(fā)支持最廣泛的網(wǎng)絡(luò)蚕苇。
11.“花費大力氣才找出問題的原因是缺少了右括號哩掺。”
調(diào)試是你必須要采取的步驟涩笤。進兩步嚼吞,退一步。盯著代碼數(shù)個小時蹬碧,以為函數(shù)名或變量作用域中有哪里搞錯了舱禽,最后才發(fā)現(xiàn)是遺漏了一個括號,這滋味恩沽,酸爽得不要不要的誊稚。所有這些時間都因為一個小小的語法錯誤而浪費。
12.“喝杯咖啡,休息一下里伯!”
有時候城瞎,你只是需要站起來,遠離顯示器疾瓮。將鼠標(biāo)懸停在鍵盤數(shù)個小時脖镀,反而有助于打破常規(guī)。大多數(shù)健康指導(dǎo)都會建議我們每隔30-60分鐘休息一會狼电。但是這一切都取決于你的需要蜒灰,如果你覺得在程序中間休息更令人懊惱的話,那就不要中斷。
13.“我應(yīng)該把這個項目束之高閣,以后再來處理它井氢。”
休息的另一個選擇是離開你的項目毕骡,而不僅僅是遠離你的電腦。如果還有其他工作需要做岩瘦,那么不妨去做其他工作未巫。相對于已經(jīng)花費了5個小時來解決問題依然不得入門而言的話,這將能更好地分配時間和資源启昧。
14.“我很懷疑古典音樂能否激發(fā)我的編程能力叙凡。”
有一種說法是密末,古典音樂可以在生命的早期階段促進植物生長握爷。我個人非常喜歡在寫復(fù)雜筆記時聆聽古典音樂。爵士樂严里、鋼琴新啼、大樂團,優(yōu)雅的音樂在全世界的人類文化中都有一席之地刹碾。那么燥撞,在編程的同時傾聽智慧的音樂真的能夠讓你更智慧地調(diào)試嗎?可能不會迷帜,不過希望它不會讓你變得更笨拙物舒。
15.“喝點酒吧,也許現(xiàn)在是檢驗鮑爾默峰值理論的好時機戏锹」诳瑁”
很多讀者都聽說過鮑爾默的峰值理論,根據(jù)一個特殊XKCD漫畫而得出锦针。簡單地說荠察,這個理論認為程序員的編碼能力在喝了一定量的酒之后置蜀,會達到一個峰值。作者名叫史蒂夫·鮑爾默割粮,他的行為古怪盾碗,就像是一個醉漢,這有一定的諷刺意味舀瓢,因為鮑爾默在微軟從來就不是一名真正的程序員。也許我們需要等待別人來實踐證明這個理論吧耗美。
16.“是不是有人動過了我的源代碼京髓?”
這聽起來有點妄想和偏執(zhí),但有時你會不由自主地懷疑商架,是不是有人在你補覺的時候堰怨,寫過這個東西了∩呙回顧過去幾周或幾個月做的項目會讓你的心不斷地往下沉备图。有時候你會發(fā)現(xiàn)一些你已經(jīng)不記得添加的東西——甚至這個項目你最近一周才剛剛瀏覽過!我為代碼而瘋狂赶袄,但你永遠不會知道…
17.“我不知道這意味著什么揽涮。”
你能遇到的最壞情況是饿肺,你對你正在瀏覽的源代碼完全不知道該怎么做蒋困。可能是你自己的項目敬辣,也可能是別人的項目雪标,但問題的根源是相同的。現(xiàn)在溉跃,你必須決定是否值得花更多的時間去搜索替代方案村刨,或仔細檢查腳本以了解它是如何工作的。
18.“我需要Google錯誤信息撰茎∏段”
在PHP中工作了多年之后,我不得不說乾吻,Google是我調(diào)試問題時的最好的朋友髓梅。使用Objective-C、C ++绎签、Java枯饿、Python和其他主要語言,也是如此诡必。錯誤信息非常有幫助奢方,但是除非你記得不同的代碼意味著什么搔扁,否則它讀起來更像是翻譯過的計算機語言。值得慶幸的是蟋字,有很多在線支持可以幫助我們確定這些錯誤信息的真正含義稿蹲。
19.“我應(yīng)該停下來,收工……但我真的很想解決它鹊奖!”
我們都有過極度灰心喪氣苛聘,想要放棄的感受,但總感覺半途而廢不是正確的選擇忠聚。于是设哗,你繼續(xù)埋首鉆研,并嘗試新的解決方案來調(diào)試两蟀。但是网梢,如果這還是意味著另一個小時的浪費呢?對于這樣的情況我并不陌生赂毯,令人非常令人沮喪战虏。
20.“哦,天哪党涕,我以前為什么不寫點注釋呢烦感?”
當(dāng)涉及到比較基礎(chǔ)的前端HTML / CSS / JS時,我們沒有必要寫注釋遣鼓。但更復(fù)雜的腳本和程序卻需要一定形式的條理組織啸盏,當(dāng)你在幾個月后,甚至若干年之后需要再回過頭來看的話骑祟。有時你會忘記注釋函數(shù)及其參數(shù)回懦、輸出格式,和其他的必要數(shù)據(jù)次企。這在一段時間之后無疑會導(dǎo)致混亂怯晕,而且,當(dāng)bug開始出現(xiàn)時缸棵,你必須調(diào)試整個腳本來尋找解決方案舟茶。因此,要是有一些有幫助的注釋就會讓你獲益良多堵第。
21.“20分鐘前它還可以工作的……”
在構(gòu)建程序時吧凉,可能最令人沮喪的部分就是,它從能工作到不能工作——而你沒有更新代碼的任何部分踏志!我發(fā)誓這是真的阀捅。而且這是沒有任何意義的事情——也許是其他程序正在運行緩存版本?有很多次你更新了一丁點代碼针余,卻導(dǎo)致了整個程序崩潰出錯饲鄙,完全停止了工作凄诞。恢復(fù)到最近可工作的復(fù)制文件忍级,然后從那里開始一步步前進帆谍。
22.“只是忘記了一個分號,然而整個程序卻因此而轟然倒下轴咱⊙打”
幾乎所有我使用的編程語言都需要結(jié)束符。雖然不是所有的語言都有嗦玖,但在C/C ++中是很常見的患雇。忘記添加結(jié)束符,不過是一個很顯然的錯誤宇挫!但是解析器不知道這一點,它會拋出一個致命錯誤酪术。于是器瘪,你不得不額外花20分鐘去搜索技術(shù)故障,而原本只需要用1秒鐘補上那個缺少的分號即可绘雁。嗯橡疼,這就是調(diào)試軟件的樂趣。
23.“我不知道讓別人來修復(fù)我的代碼庐舟,得花多少錢欣除?”
聘請另一個開發(fā)人員的點子是挺誘人的,但從財政上看顯然沒有那么可行挪略。而且如果你不親身體驗的話历帚,又怎么能從這些錯誤中學(xué)到東西呢?當(dāng)你在經(jīng)歷多次失敗之后杠娱,終于理解了某個編程概念的時候挽牢,那感覺真是棒極了。盡管如此摊求,我的腦海里依然時不時地有一種“讓別人來修復(fù)代碼”的沖頭禽拔。
24.“快速瀏覽Hackers News可以提高我的工作效率∈也妫”
很多程序員最喜歡閱讀的睹栖,有關(guān)于軟件和創(chuàng)業(yè)公司等社會新聞的選擇是Hackers News頭版。它有很多關(guān)于自由職業(yè)茧痕、時間管理野来、軟件開發(fā)、以及創(chuàng)業(yè)發(fā)布和融資的大量信息凿渊。雖然HN可以通過自我教育讓你感覺自己變得更有效率了梁只,但同時它也會浪費你的時間缚柳。每隔幾小時去快速瀏覽下Hackers News也不是那么糟糕。
25.“這個API怎么沒有文檔搪锣?秋忙!”
在使用帶有壞文檔的插件或框架時,最令人沮喪的是构舟,你必須靠自己去深入鉆研源代碼灰追。我喜歡開發(fā)人員花時間去專門設(shè)計可用文檔頁面的項目。所有的參數(shù)和選項都解釋得清清楚楚狗超,甚至可能會被用在一些示例代碼片段中弹澎。但可悲的是,事實并非總是如此努咐。所以最簡單的方法是遠離不良文檔苦蒿,不自找麻煩。
26.“我真希望我保存了那個數(shù)據(jù)庫的備份副本……”
在編寫和調(diào)試代碼時渗稍,我不會想到要備份佩迟。然而,數(shù)據(jù)備份提供了允許我們回過頭去修改的踏腳石竿屹。這在實時的服務(wù)器環(huán)境中尤為有用报强,因為有什么變化會立即執(zhí)行。以防萬一拱燃,我們應(yīng)該記得保存網(wǎng)站文件和數(shù)據(jù)庫的本地副本秉溉!雖然這會是一個惱人的任務(wù),但其惱人程度遠遠比不上重建損壞的SQL數(shù)據(jù)庫碗誉。
27.“讓它正常工作的最快解決辦法是什么召嘶?”
在花費數(shù)個小時苦苦思考自定義的解決方案之后,很明顯你需要一種新的方法诗充。在設(shè)計漂亮的界面之前苍蔬,程序員率先想到的是讓功能正常工作。確定最快蝴蜓、最準(zhǔn)確的解決方案碟绑,并實施這個解決方案讓其工作才是100%利用了時間。然后茎匠,再轉(zhuǎn)移到漂亮美觀方面格仲。
28.“我敢打賭更新我的軟件將解決這個問題∷忻埃”
管理編程語言依賴和插件的團隊并不需要經(jīng)常發(fā)布版本凯肋。有時,在你從計算機傳輸文件到實時服務(wù)器的時候汽馋,更新PHP /Ruby/ Python / SQL版本可以解決調(diào)試問題侮东。本地更新很少能夠幫助修復(fù)源代碼中的bug圈盔,除非你的版本已經(jīng)過時得無可救藥。所以悄雅,值得一試驱敲!
29.“我應(yīng)該更有條理并且去學(xué)習(xí)Git ……下周就去研究它】硐校”
開源版本控制包Git在程序員中非常受歡迎众眨。相對于其他的競爭對手,它提供了更容易的學(xué)習(xí)曲線容诬,并且被許多在線代碼倉庫娩梨,如Github上和Bitbucket使用。開發(fā)人員很容易拖延去學(xué)習(xí)Git的行動览徒,因為它對于初學(xué)者而言顯然是有難度的狈定。但是一旦你知道了基本命令,那么Git就是小菜一碟习蓬。而且它還能使調(diào)試版本控制更加清晰掸冤。
30.“算了,我還是從頭再開始吧友雳。”
有時候铅匹,在你絞盡腦汁花費數(shù)個小時之后押赊,可能要做的只是將你的工作文件移動到歸檔目錄(或刪除它們),再從頭開始就可以了包斑。但是流礁,考慮到先前已經(jīng)耗費的時間,你很難下定這個決心罗丰。但是神帅,當(dāng)我一籌莫展時,我往往會選擇從頭開始萌抵,因為這樣才有可能找到完成項目的正確道路找御。
譯文鏈接:http://www.codeceo.com/article/30-action-programmer-bug.html
英文原文:30 Common Reactions Programmers Have When Things Go Wrong
翻譯作者:碼農(nóng)網(wǎng) – 小峰