三問助你Debug

譯者按: Debug也要三省吾身!

為了保證可讀性,本文采用意譯而非直譯。另外决记,本文版權(quán)歸原作者所有,翻譯僅用于學(xué)習(xí)。

你是否發(fā)現(xiàn):有時候危纫,當(dāng)某個BUG被我們修復(fù)之后,卻又發(fā)現(xiàn)一個由該BUG引發(fā)的另一個BUG乌庶,或則由于修復(fù)算法的缺陷引入新的BUG种蝶?因此,每一次修復(fù)BUG瞒大,我都會問自己三個問題來確保我考慮周全螃征。你也可以使用同樣的方法來提高代碼的質(zhì)量。

這些精心設(shè)計的問題的核心思想是:每一個BUG都是某個隱藏的核心問題的表象透敌。你需要解決這些表面癥狀盯滚,但如果只是治標(biāo),那么終究會在其它地方復(fù)發(fā)酗电,沒有治本魄藕;你需要發(fā)現(xiàn)導(dǎo)致這個BUG的核心問題,并且糾正它撵术。導(dǎo)致出現(xiàn)BUG的核心問題一般不會隨機(jī)而無法控制背率,只要你理解了它為什么會出現(xiàn)以及什么原因?qū)е滤霈F(xiàn)。

在你對自己提出這三個問題之前,你需要克服自己的惰性退渗,仔細(xì)地去分析產(chǎn)生BUG的原因移稳。通過從出現(xiàn)BUG的代碼位置開始,一步一步問自己為什么會錯会油,往回倒著查看程序執(zhí)行步驟个粱,直到你找到出現(xiàn)這個BUG的模式。往往和同事一起Debug會有助于你證實(shí)你的假設(shè)翻翩。

程序異常是因?yàn)橄聵?biāo)變量J越界了
為什么呢都许?
數(shù)組的長度為10,下標(biāo)最大為9嫂冻,但是下標(biāo)J已經(jīng)是10了
為什么呢胶征?
J是整個數(shù)組的長度,但是可索引的下標(biāo)為9桨仿。

在尋找BUG原因的過程中睛低,同時檢查一下關(guān)鍵變量的值,看看能否解釋在此情況下服傍,變量值為何如此钱雷。

為什么name是null?
為什么會打印出一條錯誤信息吹零?

你需要知道程序到底發(fā)生了什么罩抗,也就是說要將這些信息度都記錄下來方便分析。

現(xiàn)在我們來看是看這三個問題灿椅。

1. 這個失誤在其它地方有犯過么套蒂?

看看代碼中其它地方有沒有使用過類似的編程方法,通過適當(dāng)?shù)陌l(fā)散思維也有助于尋找類似的BUG茫蛹。

  1. 其它地方有沒有使用數(shù)組的長度作為下標(biāo)操刀?
  2. 所有的數(shù)組都是源自同一個原始數(shù)組嗎?
  3. 如果數(shù)組長度為0婴洼,是否會出問題骨坑?

嘗試描述這段代碼應(yīng)當(dāng)遵循的邏輯,有BUG的代碼會違反該邏輯窃蹋。

數(shù)組起點(diǎn)的初始值加上數(shù)組的長度并減去1就是最后一個數(shù)組元素的下標(biāo)卡啰。如果數(shù)組的長度為0,則不滿足警没。

如果每次修改一個BUG的同時修復(fù)了幾個其它潛在BUG匈辱,將大大提高你的工作效率。嘗試將問題用更加抽象的角度去描述將有助于你理解整個程序杀迹,以防止引入新的BUG亡脸。

2. 在這個BUG后面是否可能隱藏著另一個BUG?

當(dāng)你已經(jīng)弄清楚如何修復(fù)這個BUG,可以預(yù)想BUG修復(fù)后的程序行為浅碾。BUG代碼行之后的語句也可能隱藏著BUG大州,只是程序以前因?yàn)锽UG崩潰而沒有執(zhí)行到這一步;或則由于修復(fù)可能返回其它值垂谢,而以前沒有考慮厦画。可以試試向自己提如下問題:

接下來的語句可以成功執(zhí)行嗎滥朱?

當(dāng)你在查看程序的控制流的時候根暑,你可以弄清楚有哪些代碼還沒有執(zhí)行過。

我是否測試過這些屬性的組合

檢查各種屬性可能性的組合并不會花費(fèi)太多工作精力徙邻,而且往往會發(fā)現(xiàn)很多情況開發(fā)者都沒有考慮到排嫌!

我可以測試出所有錯誤信息嗎?

要注意一個地方的改動可能導(dǎo)致其它地方出現(xiàn)BUG缰犁。在局部對一個變量的更改也許會違背之前的一些假設(shè)淳地。

如果我只是將J減去1,如果數(shù)組的長度為0帅容,那么下一行代碼會嘗試操作數(shù)組中位于-1位置的元素颇象。

如果你已經(jīng)對程序做了很多修改,每一次都要仔細(xì)考慮做法是否正確丰嘉,甚至需要重新設(shè)計和實(shí)現(xiàn)這部分代碼夯到。

3. 我應(yīng)該如何做來避免類似的BUG嚷缭?

你需要嘗試尋找方法從根源上解決問題饮亏。使用新的方法和工具往往可以直接消除該類型的所有BUG,而不是一個一個去發(fā)現(xiàn)和解決阅爽。

要找到BUG是什么時候引入的路幸,是否可以在開發(fā)階段避免?

設(shè)計沒有問題付翁;我在寫代碼的時候引入了BUG

仔細(xì)檢查BUG發(fā)生的原因简肴,理清BUG發(fā)生的代碼邏輯,然后看看如何糾正百侧。

定義新的不同的類型來區(qū)分?jǐn)?shù)組的索引和長度可以在編譯時發(fā)現(xiàn)這個錯誤砰识。(索引類型可以限定索引的最大長度)

每一個數(shù)組元素輸出的時候都輸出對應(yīng)的下標(biāo)的計算方法,這樣我就可以很快找到問題佣渴。

假設(shè)你對產(chǎn)生某一個BUG的理由是“變量太多辫狼,我只是忘記了”,那么你需要做的是如何改進(jìn)來保證你不需要記住很多變量辛润。

關(guān)于Fundebug

Fundebug專注于JavaScript膨处、微信小程序、微信小游戲、支付寶小程序真椿、React Native鹃答、Node.js和Java實(shí)時BUG監(jiān)控。 自從2016年雙十一正式上線突硝,F(xiàn)undebug累計處理了7億+錯誤事件测摔,得到了Google、360解恰、金山軟件避咆、百姓網(wǎng)等眾多知名用戶的認(rèn)可。歡迎免費(fèi)試用修噪!

版權(quán)聲明:

轉(zhuǎn)載時請注明作者Fundebug以及本文地址:
https://blog.fundebug.com/2017/08/23/three-questions-about-each-bug-you-find/

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末查库,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子黄琼,更是在濱河造成了極大的恐慌樊销,老刑警劉巖,帶你破解...
    沈念sama閱讀 222,464評論 6 517
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件脏款,死亡現(xiàn)場離奇詭異围苫,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)撤师,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 95,033評論 3 399
  • 文/潘曉璐 我一進(jìn)店門剂府,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人剃盾,你說我怎么就攤上這事腺占。” “怎么了痒谴?”我有些...
    開封第一講書人閱讀 169,078評論 0 362
  • 文/不壞的土叔 我叫張陵衰伯,是天一觀的道長。 經(jīng)常有香客問我积蔚,道長意鲸,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 59,979評論 1 299
  • 正文 為了忘掉前任尽爆,我火速辦了婚禮怎顾,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘漱贱。我一直安慰自己槐雾,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 69,001評論 6 398
  • 文/花漫 我一把揭開白布饱亿。 她就那樣靜靜地躺著蚜退,像睡著了一般闰靴。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上钻注,一...
    開封第一講書人閱讀 52,584評論 1 312
  • 那天蚂且,我揣著相機(jī)與錄音,去河邊找鬼幅恋。 笑死杏死,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的捆交。 我是一名探鬼主播淑翼,決...
    沈念sama閱讀 41,085評論 3 422
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼品追!你這毒婦竟也來了玄括?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 40,023評論 0 277
  • 序言:老撾萬榮一對情侶失蹤肉瓦,失蹤者是張志新(化名)和其女友劉穎遭京,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體泞莉,經(jīng)...
    沈念sama閱讀 46,555評論 1 319
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡哪雕,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,626評論 3 342
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了鲫趁。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片斯嚎。...
    茶點(diǎn)故事閱讀 40,769評論 1 353
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖挨厚,靈堂內(nèi)的尸體忽然破棺而出堡僻,到底是詐尸還是另有隱情,我是刑警寧澤幽崩,帶...
    沈念sama閱讀 36,439評論 5 351
  • 正文 年R本政府宣布苦始,位于F島的核電站寞钥,受9級特大地震影響慌申,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜理郑,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 42,115評論 3 335
  • 文/蒙蒙 一蹄溉、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧您炉,春花似錦柒爵、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,601評論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽法瑟。三九已至,卻和暖如春唁奢,著一層夾襖步出監(jiān)牢的瞬間霎挟,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,702評論 1 274
  • 我被黑心中介騙來泰國打工麻掸, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留酥夭,地道東北人。 一個月前我還...
    沈念sama閱讀 49,191評論 3 378
  • 正文 我出身青樓脊奋,卻偏偏與公主長得像熬北,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子诚隙,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,781評論 2 361

推薦閱讀更多精彩內(nèi)容