程式員的修煉-我們為什麼會編寫BUG

来源:https://www.cnblogs.com/lyy-1/archive/2020/06/29/13207162.html
-Advertisement-
Play Games

在最近的一周,我維護的業務系統出現了很多壞毛病,一周七天crash掉了4次,每次都需要都是因為一點很小的問題,觸發了蝴蝶效應,導致整個系統全盤崩潰,於是產生除了敘述本篇的想法,當然這並不是為了掩蓋我在Coding上的一些細節處理和職責疏忽,只是為了從根本的細節上去分析這些問題。 (一、)為什麼會產生 ...


在最近的一周,我維護的業務系統出現了很多壞毛病,一周七天crash掉了4次,每次都需要都是因為一點很小的問題,觸發了蝴蝶效應,導致整個系統全盤崩潰,於是產生除了敘述本篇的想法,當然這並不是為了掩蓋我在Coding上的一些細節處理和職責疏忽,只是為了從根本的細節上去分析這些問題。

(一、)為什麼會產生BUG
首先我們需要嘗試理解一下什麼Bug?

關於bug的解釋

bug 是指任何電腦程式或硬體系統中的錯誤,故障或缺陷。錯誤會產生意外結果或導致系統意外運行
簡單來說:bug就是程式出了問題,產生了意外的結果,沒有按照預期的結果去運行。

產生Bug的原因有很多種:

    開發者水平太低
   不同的編譯及運行環境
   與需求方溝通不到位
   馬虎大意、考慮不周
   放飛自我,Coding全靠自嗨
   選擇了錯誤的或者運行不穩定的第三方庫
以上原因總結,主觀和客觀因素都會影響到Bug的產生,正如誤差不可避免一般,我們應該對自己寫出的代碼進行測試、分析、"溝通".

(二、)如何儘量避免Bug

鑒於以上bug產出的原因,我們可以通過這些一些對策來避免Bug的產生,下麵是一些常見原因分析和處理對策。

1.開發者水平太低

在進行系統的構建中,部分開發者可能通常因為開發經驗過少,或者語言不熟悉,會編寫錯誤的代碼,然後未經過代碼測試和審計,便進行提交和上線操作,導致了異常的引發

解決方案:

如果是語法錯誤,可通過一些ide的代碼檢測器,或者語法檢查來檢測代碼可否正常運行.
如果是PHP等弱類型語言,可使用靜態代碼掃描工具來發現程式中明顯的語法錯誤.
編寫足夠的測試用例,覆蓋整個模塊的語句
請求你的伙伴進行CodeReview(代碼審計),來改善代碼的質量和發現代碼中的缺陷
2.不同的編譯及運行環境

因為業務的拓展和服務支持,需要部署多個不同的運行環境中,如:轉賬系統,你在測試環境中轉賬了1000元給用戶小明,小明卻在生產環境中收到了這1000元,併成功進行提現,往往因為沒有環境判斷,導致了失誤的操作!

解決方案:

1.在代碼中多進行註釋說明,標明哪些函數會在其他環境中操作和運行

2.加強環境邏輯判斷

以下是我在使用的一些標註和說明,其他開發者或我本人再次閱覽該代碼時,就會得到一個清晰的運行結果.

 /**
 * 執行該函數時,會根據env環境進行處理,詳細如下
 * prod(生產環境):會啟動隊列對視頻進行轉碼、截圖、寫入到生產資料庫中操作.
 * staging(預演環境):不會啟動隊列,但會寫入staging資料庫中
 * test(測試環境):會啟動隊列對視頻進行轉碼、截圖、寫入到測試資料庫中操作.
 */
$video = $this->uploadVideo($file);
$queue = $this->videoQueue($video);

 3.與需求方溝通不到位

這是經常程式員與產品對撕的一個很重要原因,TA想要A,而你卻做出了B,於是你們產生了很大的爭論

解決方案:

多進行溝通,需求進行反覆確認,不要上手就進行編碼,先進行分析。
通過PM系統,留存需求規劃與變更記錄,以便每一次業務更改,都得能與系統中的問題對上號.
 4.馬虎大意、考慮不周

編碼時以為問題很小,修改代碼,不走調試與測試流程,直接上線.

解決方案:

不要盲目過於自信,相信自己的主觀判斷,一定走測試流程,確保改動無誤!(這是我之前經常犯的錯,然後系統出了問題,我的fix commit從1變成了N....)
CodeReview(代碼審計),這是一個最好的辦法,當然需要耗費不少的人力,但是能最大的去降低缺陷和錯誤.

1 目前,我也組建了一個自學群,可以一起討論研究前端的各個事宜,以及提高能力的方法,只要你想瞭解前端,精通前端,都歡迎你們加入我們的前端自學。
2 你可以找到志同道合的朋友,相互激勵的學習伙伴,還能得到大神的經驗分享,和加入項目實戰的機會。這是我的WEB前端q裙。---851231348
3 整理了-套最新的前端基礎教程,學習前端的這個過程當中我也收集了很多前端學習手冊,面試題,開發工具,PDF文檔書籍教程,可以直接分享給你們。

5.放飛自我,Coding全靠自嗨

解決方案:

這類朋友不適合做開發者,適合去做創造者!

6.選擇了錯誤的或者運行不穩定的第三方庫

有時候為了省略接入時間,往往會忽略掉一些大型庫,因為業務的支持只用到了一小部分,所以我們有時候會去選擇一些mini庫,最後由於不穩定或方案不成熟,出現錯誤的運行結果

解決方案:

如果業務級別比較高的話,不建議採用冷門或者無人問津的mini庫使用,因為出現問題的損失會更大.
進行反覆測試,開發人員對核心代碼進行閱覽,確保正常無誤.
自我組織編寫或實現,但是學習和開發成本比較高,小型規模不建議採取.

(三、)多與代碼進行"溝通"

“橡皮鴨調試法”是我在閱讀《編寫可讀代碼》一書中看到的一個技巧,我在一個人開發的時候會使用這個技巧,我認為是一個不錯的選擇.

 

 

(四、)總結

我們為什麼會編寫BUG,如果沒有BUG?開發和測試不就失業了嗎?當然這隻是一句玩笑話。
在此引用知乎上一句很有意思的話.


編碼也亦如此,因為很多主觀和客觀的因素,導致程式執行了錯誤的邏輯,產生了不如預期的結果,作為一個合格的開發人員,我們應該儘力確保程式穩妥運行,減少失誤和異常。

正如CZG提到的"你寫的每一行代碼,都是你的名片",我們每個人都義務去維護好這張名片,讓其他人對這張名片充滿敬畏之心,而不是"what shit code",諸君共勉!

 

 

 

 



 



 

 



 



 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 基本類型(棧數據) String Number Boolean null undefined symbol(ES6) 引用類型(堆數據) Array Object Function Date RegExp 等 區分 棧小堆大 1.基礎類型是放置在棧裡面,一般基礎類型的數據都比較小,賦值不影響自身 v ...
  • vue是數據驅動視圖更新的框架, 所以對於vue來說組件間的數據通信非常重要,那麼組件之間如何進行數據通信的呢? 首先我們需要知道在vue中組件之間存在什麼樣的關係, 才更容易理解他們的通信方式, 就好像過年回家,坐著一屋子的陌生人,相互之間怎麼稱呼,這時就需要先知道自己和他們之間是什麼樣的關係。 ...
  • 延遲函數delay const delay = ms => new Promise((resolve, reject) => setTimeout(resolve, ms)) ​ const getData = status => new Promise((resolve, reject) => { ...
  • 前言 watch 是由用戶定義的數據監聽,當監聽的屬性發生改變就會觸發回調,這項配置在業務中是很常用。在面試時,也是必問知識點,一般會用作和 computed 進行比較。 那麼本文就來帶大家從源碼理解 watch 的工作流程,以及依賴收集和深度監聽的實現。在此之前,希望你能對響應式原理流程、依賴收集 ...
  • 標簽的分類 1. 雙標簽 又叫常規標簽 : 有開始標簽和結束標簽 eg: <div></div> <body></body> … 2. 單標簽 又叫空標簽 : 只有開始標簽 eg : <br> <img> <meta> … 標簽的說明 代碼只有要嵌套就會出現縮進, head 和body可以不縮進在 ...
  • 動態實現簡單的二級菜單 當滑鼠放到一級標簽上時,滑鼠會變成小手的形狀 展示二級菜單,源碼如下,複製即可直接使用 1 <!DOCTYPE html> 2 <html lang="en"> 3 <head> 4 <meta charset="UTF-8"> 5 <meta name="viewport" ...
  • dangerouslySetInnerHTML dangerouslySetInnerHTML 是 React 為瀏覽器 DOM 提供 innerHTML 的替換方案。通常來講,使用代碼直接設置 HTML 存在風險,因為很容易無意中使用戶暴露於跨站腳本(XSS)的攻擊。因此,你可以直接在 React ...
  • 先上預覽地址 http://106.12.212.110:8077/#/ 1.創建項目 使用vue init webpack temperaure 創建一個vue項目 然後安裝axios zrender 命令分別是 npm install axios -S npm install zrender安裝 ...
一周排行
    -Advertisement-
    Play Games
  • 概述:在C#中,++i和i++都是自增運算符,其中++i先增加值再返回,而i++先返回值再增加。應用場景根據需求選擇,首碼適合先增後用,尾碼適合先用後增。詳細示例提供清晰的代碼演示這兩者的操作時機和實際應用。 在C#中,++i 和 i++ 都是自增運算符,但它們在操作上有細微的差異,主要體現在操作的 ...
  • 上次發佈了:Taurus.MVC 性能壓力測試(ap 壓測 和 linux 下wrk 壓測):.NET Core 版本,今天計劃準備壓測一下 .NET 版本,來測試並記錄一下 Taurus.MVC 框架在 .NET 版本的性能,以便後續持續優化改進。 為了方便對比,本文章的電腦環境和測試思路,儘量和... ...
  • .NET WebAPI作為一種構建RESTful服務的強大工具,為開發者提供了便捷的方式來定義、處理HTTP請求並返迴響應。在設計API介面時,正確地接收和解析客戶端發送的數據至關重要。.NET WebAPI提供了一系列特性,如[FromRoute]、[FromQuery]和[FromBody],用 ...
  • 原因:我之所以想做這個項目,是因為在之前查找關於C#/WPF相關資料時,我發現講解圖像濾鏡的資源非常稀缺。此外,我註意到許多現有的開源庫主要基於CPU進行圖像渲染。這種方式在處理大量圖像時,會導致CPU的渲染負擔過重。因此,我將在下文中介紹如何通過GPU渲染來有效實現圖像的各種濾鏡效果。 生成的效果 ...
  • 引言 上一章我們介紹了在xUnit單元測試中用xUnit.DependencyInject來使用依賴註入,上一章我們的Sample.Repository倉儲層有一個批量註入的介面沒有做單元測試,今天用這個示例來演示一下如何用Bogus創建模擬數據 ,和 EFCore 的種子數據生成 Bogus 的優 ...
  • 一、前言 在自己的項目中,涉及到實時心率曲線的繪製,項目上的曲線繪製,一般很難找到能直接用的第三方庫,而且有些還是定製化的功能,所以還是自己繪製比較方便。很多人一聽到自己畫就害怕,感覺很難,今天就分享一個完整的實時心率數據繪製心率曲線圖的例子;之前的博客也分享給DrawingVisual繪製曲線的方 ...
  • 如果你在自定義的 Main 方法中直接使用 App 類並啟動應用程式,但發現 App.xaml 中定義的資源沒有被正確載入,那麼問題可能在於如何正確配置 App.xaml 與你的 App 類的交互。 確保 App.xaml 文件中的 x:Class 屬性正確指向你的 App 類。這樣,當你創建 Ap ...
  • 一:背景 1. 講故事 上個月有個朋友在微信上找到我,說他們的軟體在客戶那邊隔幾天就要崩潰一次,一直都沒有找到原因,讓我幫忙看下怎麼回事,確實工控類的軟體環境複雜難搞,朋友手上有一個崩潰的dump,剛好丟給我來分析一下。 二:WinDbg分析 1. 程式為什麼會崩潰 windbg 有一個厲害之處在於 ...
  • 前言 .NET生態中有許多依賴註入容器。在大多數情況下,微軟提供的內置容器在易用性和性能方面都非常優秀。外加ASP.NET Core預設使用內置容器,使用很方便。 但是筆者在使用中一直有一個頭疼的問題:服務工廠無法提供請求的服務類型相關的信息。這在一般情況下並沒有影響,但是內置容器支持註冊開放泛型服 ...
  • 一、前言 在項目開發過程中,DataGrid是經常使用到的一個數據展示控制項,而通常表格的最後一列是作為操作列存在,比如會有編輯、刪除等功能按鈕。但WPF的原始DataGrid中,預設只支持固定左側列,這跟大家習慣性操作列放最後不符,今天就來介紹一種簡單的方式實現固定右側列。(這裡的實現方式參考的大佬 ...