譯者按: Debug也要三省吾身!
成都創(chuàng)新互聯(lián)公司網(wǎng)站建設(shè)公司是一家服務(wù)多年做網(wǎng)站建設(shè)策劃設(shè)計制作的公司,為廣大用戶提供了成都網(wǎng)站建設(shè)、成都網(wǎng)站設(shè)計,成都網(wǎng)站設(shè)計,廣告投放平臺,成都做網(wǎng)站選成都創(chuàng)新互聯(lián)公司,貼合企業(yè)需求,高性價比,滿足客戶不同層次的需求一站式服務(wù)歡迎致電。原文: Three Questions About Each Bug You Find
為了保證可讀性,本文采用意譯而非直譯。另外,本文版權(quán)歸原作者所有,翻譯僅用于學習。
你是否發(fā)現(xiàn):有時候,當某個BUG被我們修復(fù)之后,卻又發(fā)現(xiàn)一個由該BUG引發(fā)的另一個BUG,或則由于修復(fù)算法的缺陷引入新的BUG?因此,每一次修復(fù)BUG,我都會問自己三個問題來確保我考慮周全。你也可以使用同樣的方法來提高代碼的質(zhì)量。
這些精心設(shè)計的問題的核心思想是:每一個BUG都是某個隱藏的核心問題的表象。你需要解決這些表面癥狀,但如果只是治標,那么終究會在其它地方復(fù)發(fā),沒有治本;你需要發(fā)現(xiàn)導致這個BUG的核心問題,并且糾正它。導致出現(xiàn)BUG的核心問題一般不會隨機而無法控制,只要你理解了它為什么會出現(xiàn)以及什么原因?qū)е滤霈F(xiàn)。
在你對自己提出這三個問題之前,你需要克服自己的惰性,仔細地去分析產(chǎn)生BUG的原因。通過從出現(xiàn)BUG的代碼位置開始,一步一步問自己為什么會錯,往回倒著查看程序執(zhí)行步驟,直到你找到出現(xiàn)這個BUG的模式。往往和同事一起Debug會有助于你證實你的假設(shè)。
程序異常是因為下標變量J越界了
為什么呢?
數(shù)組的長度為10,下標大為9,但是下標J已經(jīng)是10了
為什么呢?
J是整個數(shù)組的長度,但是可索引的下標為9。
在尋找BUG原因的過程中,同時檢查一下關(guān)鍵變量的值,看看能否解釋在此情況下,變量值為何如此。
為什么name是null?
為什么會打印出一條錯誤信息?
你需要知道程序到底發(fā)生了什么,也就是說要將這些信息度都記錄下來方便分析。
現(xiàn)在我們來看是看這三個問題。
看看代碼中其它地方有沒有使用過類似的編程方法,通過適當?shù)陌l(fā)散思維也有助于尋找類似的BUG。
- 其它地方有沒有使用數(shù)組的長度作為下標?
- 所有的數(shù)組都是源自同一個原始數(shù)組嗎?
- 如果數(shù)組長度為0,是否會出問題?
嘗試描述這段代碼應(yīng)當遵循的邏輯,有BUG的代碼會違反該邏輯。
數(shù)組起點的初始值加上數(shù)組的長度并減去1就是最后一個數(shù)組元素的下標。如果數(shù)組的長度為0,則不滿足。
如果每次修改一個BUG的同時修復(fù)了幾個其它潛在BUG,將大大提高你的工作效率。嘗試將問題用更加抽象的角度去描述將有助于你理解整個程序,以防止引入新的BUG。
當你已經(jīng)弄清楚如何修復(fù)這個BUG,可以預(yù)想BUG修復(fù)后的程序行為。BUG代碼行之后的語句也可能隱藏著BUG,只是程序以前因為BUG崩潰而沒有執(zhí)行到這一步;或則由于修復(fù)可能返回其它值,而以前沒有考慮??梢栽囋囅蜃约禾崛缦聠栴}:
接下來的語句可以成功執(zhí)行嗎?
當你在查看程序的控制流的時候,你可以弄清楚有哪些代碼還沒有執(zhí)行過。
我是否測試過這些屬性的組合
檢查各種屬性可能性的組合并不會花費太多工作精力,而且往往會發(fā)現(xiàn)很多情況開發(fā)者都沒有考慮到!
我可以測試出所有錯誤信息嗎?
要注意一個地方的改動可能導致其它地方出現(xiàn)BUG。在局部對一個變量的更改也許會違背之前的一些假設(shè)。
如果我只是將J減去1,如果數(shù)組的長度為0,那么下一行代碼會嘗試操作數(shù)組中位于-1位置的元素。
如果你已經(jīng)對程序做了很多修改,每一次都要仔細考慮做法是否正確,甚至需要重新設(shè)計和實現(xiàn)這部分代碼。
你需要嘗試尋找方法從根源上解決問題。使用新的方法和工具往往可以直接消除該類型的所有BUG,而不是一個一個去發(fā)現(xiàn)和解決。
要找到BUG是什么時候引入的,是否可以在開發(fā)階段避免?
設(shè)計沒有問題;我在寫代碼的時候引入了BUG
仔細檢查BUG發(fā)生的原因,理清BUG發(fā)生的代碼邏輯,然后看看如何糾正。
定義新的不同的類型來區(qū)分數(shù)組的索引和長度可以在編譯時發(fā)現(xiàn)這個錯誤。(索引類型可以限定索引的大長度)
每一個數(shù)組元素輸出的時候都輸出對應(yīng)的下標的計算方法,這樣我就可以很快找到問題。
假設(shè)你對產(chǎn)生某一個BUG的理由是“變量太多,我只是忘記了”,那么你需要做的是如何改進來保證你不需要記住很多變量。
Fundebug專注于JavaScript、微信小程序、微信小游戲、支付寶小程序、React Native、Node.js和Java實時BUG監(jiān)控。 自從2016年雙十一正式上線,F(xiàn)undebug累計處理了7億+錯誤事件,得到了Google、360、金山軟件、百姓網(wǎng)等眾多知名用戶的認可。歡迎免費試用!
轉(zhuǎn)載時請注明作者Fundebug以及本文地址:
https://blog.fundebug.com/2017/08/23/three-questions-about-each-bug-you-find/
另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)scvps.cn,海內(nèi)外云服務(wù)器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國服務(wù)器、虛擬主機、免備案服務(wù)器”等云主機租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務(wù)可用性高、性價比高”等特點與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場景需求。
網(wǎng)站題目:三問助你debug-創(chuàng)新互聯(lián)
本文來源:http://muchs.cn/article10/idpgo.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站改版、定制開發(fā)、網(wǎng)站收錄、移動網(wǎng)站建設(shè)、品牌網(wǎng)站設(shè)計、標簽優(yōu)化
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)
猜你還喜歡下面的內(nèi)容