修復bug的12個關鍵步驟

要多少時間才能修復bug,事先是很難知道的,特別是如果你和這些代碼還素不相識的話,情況就更加撲朔迷離了。James Shore在《The Art of Agile?》一書中,明確指出要想修復問題得先知道問題的所在。而我們之所以無法準確估計時間是因為我們不知道需要多久才能發現癥結的所在,只有清楚這一點,我們才能合理估計修復bug所需要花費的時間。不過,這個時候恐怕黃花菜都涼了。?Steve McConnell曾說過:

“發現問題—理解問題—這就是程序員90%的工作。”

很多bug都只需改動某一行代碼即可。但是需要投入大量時間的是,后面還得指出怎么樣才是正確的——就像我們在釣魚的時候,得知道往哪里下誘餌,什么時候魚兒容易上鉤等等。話說bug有四種類型:第一種易尋易修復,第二種難尋易修復,第三種易尋難修復,第四種難尋難修復。最悲劇的就是最后一型的,不但“尋尋覓覓,凄凄涼涼戚戚”,哪怕終于千辛萬苦滴水穿石,也只能在那邊不由自主地抓耳撓腮,無奈嘆一句“路漫漫其修遠兮”。可以這么說,除非是新鮮出爐的代碼,不然讓你找bug就跟瞎子摸象一樣——糊里糊涂,不知道歸屬于哪種bug類型。

查找和修復bug

你知道“查找和修復bug”意味著什么嗎?沒錯,就是調試!不斷的調試,無數次的調試!Paul Butcher通過大量工作,總結出以下結構化的步驟:

1.明確目的。仔細查閱異常報告,確定是否是個bug,找出各種有用的信息發現問題的癥結,予以重現。再次檢查是否與報告發生重復。如果發生重復,那看看曾經的相關人員是如何處理的。

2.準備工作——找出正確的代碼,用排除法清理工作區域。

3.匹配測試環境。如果客戶正在操作計算機配置,那么此過程可以跳躍。

4.明確代碼的用途,確保現有測試工具一切正常。

5.好了,現在可以出發釣魚去咯——重現和診斷錯誤。如果你不能做到重現,那你就不能證明你已經完成修復工作。

6.編寫測試案例,或者通過現成的測試案例來捕獲bug。

7.進入修復模式——請務必確保不會影響到其他任何部分。但是,在開展修復工作之前,可能你還要包攬重構工作,因為只有這樣,你才能無所顧忌地搗鼓代碼。而且事后回歸測試,還能確保你不會加入任何新的bug。

8.整理代碼。通過一步一步重構,讓你的代碼更易于理解,更安全。

9.找別人來審查一下,當局者迷旁觀者清。

10.再次檢查此修復過程

11.試著不從主線出發,以檢查這些bug是否會影響其他支線。合并這些變化,處理代碼中的差異,回顧所有的審查和測試等工作。

12.思考。好好想一想哪里錯了以及為什么錯了?為什么你的修復會起效?這種類型的bug還會出現在哪里?在《?The Pragmatic Programmer》一書中,Andy Hunt?和Dave Thomas也如是指出“如果一個bug需要耗費你很多時間,那么一定要好好弄清楚原因”。此外,還需要思考的是,怎么做才能吸取經驗教訓,將來在類似的問題上不再栽跟頭?以及,我們采用的方法、使用的工具是否還有可以改進的地方?以及這些bug的影響和嚴重程度。

找到bug,還是修復bug,哪個需要更多時間?

或許建立一個測試環境、重現問題和測試bug所需的時間,要遠遠多于找到bug和修復bug的時間。不過對于一小部分顯而易見的bug,找到它們很簡單——不過修復起來可能就不盡如人意了。

在《Making Software》一書中,有一章主要是探討“大部分的軟件漏洞的來源”,Dewayne Perry分析認為,相較于修復,發現bug(包括理解bug和重現bug)所需時間更長。有研究表明,大多數的bug(差不多有3/4)既易于發現又易于修復:5天或許更少(這是基于大規模實時系統通過重量級SDLC、大量審查和測試得出的數據)。但是也有很惡心的bug,即便你可以輕輕松松揪到它,還是還得“嘔心瀝血”才能修復好。

發現/修復修復時間<=5天修復時間>5天
能重現問題72.5%18.4%
難以重現或根本沒法重現5.9%3.2%

所以如果你打賭說你能很快修復bug,大多數情況下你還真沒說錯。不過當你打賭輸了的時候,那么,嘿嘿,就意味著你有大麻煩了。

所以,下次,boss再問什么時候能修復bug,別再傻乎乎地回答“馬上就能搞定”了。

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/447295.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/447295.shtml
英文地址,請注明出處:http://en.pswp.cn/news/447295.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

Java JUC工具類--Master-Worker

Master-Worker Master-Worker模式是常用的并行計算模式。它的核心思想是系統由兩類進程協作工作&#xff1a;Master進程和Worker進程Master負責接收和分配任務&#xff0c;Worker負責處理子任務當各個Worker子進程處理完成后&#xff0c;會將結果返回給Master&#xff0c;由Ma…

身體打來的電話,你一定要接!

心臟有問題時。左邊手臂會酸、麻、痛。肝臟有問題時。小腿晚上睡覺時容易抽筋。腎臟出現問題時。聲音就會出不來&#xff0c;就會沙啞。脾胃出現問題時。偏頭痛。附&#xff1a;五臟排毒最簡單有效的方法 一、心臟有問題時 1。呼吸會不順暢&#xff0c;胸口會悶也會刺痛&…

Java JUC工具類--Semaphore

Semaphore 在Semaphore信號量非常適合高并發訪問限制&#xff0c;新系統在上線之前&#xff0c;要對系統的訪問量進行評估&#xff0c;評估是經過以往的經驗、數據、歷年的訪問量&#xff0c;已經推廣力度進行一個合理的評估當然評估標準不能太大也不能太小&#xff0c;太大的…

python 基礎知識點整理 和具體應用

Python教程 Python是一種簡單易學&#xff0c;功能強大的編程語言。它包括了高效的高級數據結構和簡單而有效的方法&#xff0c;面向對象編程。Python優雅的語法&#xff0c;動態類型&#xff0c;以及它天然的解釋能力&#xff0c;使其成為理想的語言&#xff0c;腳本和應用程序…

Java 線程池相關問題

線程池的拒絕策略 AbortPolicy&#xff1a;直接拋出異常阻止系統正常工作。CallerRunsPolicy&#xff1a;只要線程池未關閉&#xff0c;該策略直接在調用者線程中&#xff0c;運行當前被丟棄的任務。DiscardOldestPolicy&#xff1a;丟棄最老的一個請求&#xff0c;嘗試再次提…

對編程人員我想說:多做 多實踐 多寫代碼

有很多人問我&#xff0c;怎樣提高自己的能力&#xff1f;有初學者&#xff0c;有水平達到一定程度的程序員。 我想說&#xff0c;不要過多的看代碼&#xff0c;看計算機理論&#xff0c;看別人寫的文章&#xff0c;代碼等&#xff0c;最重要的是自己理解了某個原理&#xff0c…

讀人是基礎,看人是關鍵,做人最重要

人生在世&#xff0c;讀人是基礎&#xff0c;看人是關鍵&#xff0c;做人最重要。 一、讀人——一個人就是一本書。讀人&#xff0c;比讀其他文字的書更難。在生活中&#xff0c;每個人都是書&#xff0c;每人又都是讀者。我們認認真真地讀&#xff0c;讀了大半輩子&#xff0c…

使用postman模擬百度通用文字識別

1&#xff0c;登錄百度AI開放平臺 百度AI網站新手指南鏈接在頂部導航欄中&#xff0c;找到控制臺選項&#xff0c;輸入賬號和密碼&#xff0c;進入管理中心頁面在管理中心頁面中&#xff0c;找到文字識別的選項找到創建應用的選項&#xff0c;進行ocr項目的創建需要輸入應用的…

3個觀念 不再瞎學習!

此刻&#xff0c;你應該要做什么準備&#xff1f;加碼股市還是追逐房市&#xff1f;都不是。在你分配時間、資源的投資組合里&#xff0c;有沒有這一項&#xff1a;“自己”&#xff1f; 沒有人會否認充實自我的重要&#xff0c;但是經歷一場金融風暴大震撼&#xff0c;當企業…

Java調用百度OCR文字識別的接口

調用百度OCR文字識別的接口&#xff0c;來自于百度官網&#xff0c;親測可以使用 跳轉鏈接FileUtil的下載鏈接Base64Util下載鏈接HttpUtil下載鏈接GsonUtils下載鏈接Accurate.java文件 package com.baidu.ai.aip;import com.baidu.ai.aip.utils.Base64Util; import com.baidu.…

做好7步 迅速成為行業專家

行行出狀元&#xff0c;但不一定人人能成為行業專家或權威。無論是做獨立顧問&#xff0c;還是手下有250名員工的工廠主管&#xff0c;都是在用自己多年豐富經驗在幫助企業成功。既然有了專業知識和經驗&#xff0c;為什么不把它最大化利用&#xff0c;來建立自己的行業權威&am…

redis常用命令與特性

keys * 返回滿足條件的所有key&#xff0c;可以模糊匹配select 數字0-15&#xff0c;進行數據庫切換&#xff0c;默認0-15個exists 是否存在指定的keypersist 取消過期時間 select 選擇數據庫 &#xff08;0-15&#xff0c;總共16個數據庫&#xff09;move key index 將當前數據…

緊急不代表重要:管理時間的六個秘密

當整個世界都永遠在跟集中精神做事做對的時候&#xff0c;怎么辦&#xff1f;Managershare&#xff1a;“世界上效率最高的程序員有什么相同之處&#xff1f;不是經驗&#xff0c;薪水或者花在一個項目上的時間&#xff0c;而是他們的老板創造了一個免于走神的環境。”這老板太…

redis安全

定期打補丁禁止一些高危命令 &#xff08;flushdb、keys *、flushall&#xff09;以低權限運行 Redis 服務禁止外網訪問 Redis設置訪問密碼 足夠復雜&#xff0c;防止暴力破解 requirepass xxxxxxxx訪問權限 內網通過acl限制可以訪問redis的ip和端口

如何在三個月內獲得三年的工作經驗

在多年的工作生涯中&#xff0c;總會目睹一批人的升職像火箭速度一樣。 而總有一批人&#xff0c;就像蝸牛一樣&#xff0c;工作崗位和職位幾乎從來不變。 我們看看&#xff0c;2個名人的快速成長史。 一個是教英語的李陽&#xff0c;他讀大學時成績不好&#xff0c;英語不…

Redis Cluster集群模式

Redis Cluster 它是Redis的分布式解決方案&#xff0c;在Redis 3.0版本正式推出的&#xff0c;有效解決了Redis分布式方面的需求。當遇到單機內存、并發、流量等瓶頸時&#xff0c;可以采用Cluster架構達到負載均衡的目的。數據分布理論: 分布式數據庫首要解決把整個數據集按照…

永遠和靠譜的人在一起!

巴菲特每年都會同大學生進行座談&#xff0c;在一次交流會上&#xff0c;有學生問他&#xff1a;您認為一個人最重要的品質是什么?巴菲特沒有正面回答這個問題&#xff0c;而是講了一個小游戲&#xff0c;名為&#xff1a;買進你同學的10%。 巴菲特說&#xff1a;現在給你們一…

Redis事務詳解

傳統事務的特性 原子性一致性隔離性&#xff1a;事務之間互不干擾持久化&#xff1a;一旦事務提交&#xff0c;無法修改 Redis事務機制 MULTI、EXEC、DISCARD和WATCH命令是Redis事務功能的基礎。Redis事務允許在一次單獨的步驟中執行一組命令&#xff0c;并且可以保證如下兩個…

工作的最終目的

當時公司招了大批應屆本科和研究生畢業的新新人類。平均年齡25歲。那個新的助理&#xff0c;是經過多次面試后&#xff0c;我親自招回來的一個女孩。名牌大學本科畢業&#xff0c;聰明&#xff0c;性格活潑。私下里我得承認&#xff0c;我招她的一個很重要的原因&#xff0c;除…

銷售員所做的一切工作最終目的就是為了成交

&#xff08;1&#xff09;最后一次報價禁忌.報價過晚或者過于匆忙步幅度太大&#xff0c;顯得過于慷慨;讓步幅度太小&#xff0c;顯得毫無意義當談判進展到最后&#xff0c;雙方只是在最后的某一兩個問題上尚有不同意見&#xff0c;過讓步才能求得一致&#xff0c;簽訂協議。在…