Go語言之調試

調試是一種技能,不限於我們說的debug,這只是其中的一種,這是可以打斷點的調試,除此之外,還有打印輸出、日誌記錄、單元測試,這都可以稱之爲調試程序的手段。


打印輸出


打印輸出是一種比較傳統的調試手段,我們可以把我們需要了解的變量值,執行的步驟等打印出來,來證明我們的猜測,以便解決問題。


func min(a,b int) int {
    //調試輸出
    fmt.Println("a:",a,",b:",b)    
    if a>b { 
           return b  
  
} else {                   return a  
  
}
}


這是一個求最小值的函數,其中的fmt.Println("a:",a,",b:",b) 就是我們加入的調試輸出語句,這樣我們就可以看到被比較的兩個數的值,進而推測我們求最小值的算法是否正確。


打印輸出不僅可以輸出數值,還可以通過測試是否有輸出來判斷程序走了哪個邏輯,比如if語句,可能因爲比較的錯誤,程序進入了另外一個if分支,那麼我們就可以通過使用打印輸出來判斷。


日誌輸出


這個和打印非常像,但是他比打印多了很多信息,比如發生時間,發生的代碼行數等,這種尤其在我們遇到線上問題的時候尤其有用。


比如我們監控到有一些部分用戶的登陸一直失敗,那麼我們就就可以通過我們的日誌文件裏的日誌,來定位時間、IP、用戶、錯誤信息以及代碼行等,最終找到問題,解決問題。關於日誌的適用可以參考我以前的一篇文章 http://www.flysnow.org/2017/05/06/go-in-action-go-log.html,這裏就不再詳細介紹了。


GDB調試


GDB是一款類Unix下的調試器,可以幫助我們調試可執行的程序,Go也對GDB進行了支持,所以我們也可以適用GDB調試go程序。


GDB是命令行的工具,在調試前,我們要先編譯出我們需要調試的程序。使用go build -gcflags "-N -l" main.go即可進行編譯。這裏-N -l的標記是忽略編譯器優化的意思,這樣我們就可以更容易的調試程序。


調試通過gdb main啓動,會進入一個GDB的調試界面,在這裏面我們可以通過list命令查看代碼,可以通過b命令對某一行打斷點,可以通過run命令運行等,具體的可以參考GDB相關文檔,這裏不做詳細介紹。


Delve調試


Delve是一個專門爲調試Go程序而生的調試工具,它比GDB更強大,尤其時調試多goroutine高併發的Go程序。Delve的項目地址爲https://github.com/derekparker/delve,它業績大部分Go開發IDE選用的調試工具,比如Goland,後面我們再介紹。


Delve的使用和GDB非常像,都是命令行的工具,我們可以通過dlv debug main.go啓動,然後就會進入一個交互界面,在這個界面裏我們就可以進行調試操作了。


Delve的一些常用命令如下:


1.break 打斷點


  1. continue 運行到斷點處

  2. clear 刪除斷點

  3. list 顯示源代碼

  4. next 運行到下一行

  5. locals 打印局部變量

  6. print 打印一個變量或者表達式

  7. exit 退出調試


除此之外,還有很多,大家可以參考Delve的文檔進行調試。


IDE調試


對於調試來說,命令行下的太麻煩了,所以爲了工具效率,建議大家使用IDE進行調試,可見,逐行,效率高。


調試這個事情,只要可以解決我們的問題就好,有一個好的IDE可以幫助我們更高效率的調試,何樂不爲呢。


這裏推薦Goland,Jetbrains出品,老牌IDE廠商,非常方便。它家有很多IDE,而且快捷鍵都一樣了,會了一個其他的也都會了。


IDE調試非常簡單,點擊工具欄的啓動調試按鈕,就可以調試了,記得提前打上斷點。然後F8和F7配合就可以調試了,有專門的調試窗口可以看當前的局部變量,堆棧信息等,很簡單,這裏不做詳細介紹了。


單元測試


單元測試也是一種調試的手段,我們可以模擬很多場景來驗證我們邏輯的正確性,遇到問題,打印輸出等,所以也是一種調試的手段


發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章