濮阳杆衣贸易有限公司

主頁 > 知識庫 > Golang捕獲panic堆棧信息的講解

Golang捕獲panic堆棧信息的講解

熱門標簽:南通如皋申請開通400電話 廣州呼叫中心外呼系統(tǒng) 高德地圖標注口訣 學海導航地圖標注 地圖標注的汽車標 浙江高速公路地圖標注 江西轉化率高的羿智云外呼系統(tǒng) 西部云谷一期地圖標注 中國地圖標注省會高清

golang當中panic的時候如果啟動的goroutine比較多,刷的信息滿屏都是,在終端工具上因為刷的信息太多,找不到前邊的信息,因此很有必要程序自己捕獲panic,并且將錯誤信息輸出到文件當中,以便定位排查問題。

Golang捕獲panic堆棧信息

func PanicTrace(kb int) []byte {
  s := []byte("/src/runtime/panic.go")
  e := []byte("\ngoroutine ")
  line := []byte("\n")
  stack := make([]byte, kb10) //4KB
  length := runtime.Stack(stack, true)
  start := bytes.Index(stack, s)
  stack = stack[start:length]
  start = bytes.Index(stack, line) + 1
  stack = stack[start:]
  end := bytes.LastIndex(stack, line)
  if end != -1 {
    stack = stack[:end]
  }
  end = bytes.Index(stack, e)
  if end != -1 {
    stack = stack[:end]
  }
  stack = bytes.TrimRight(stack, "\n")
  return stack
}

該函數(shù)的優(yōu)點:

  • 比直接recover()捕獲的panic信息更加詳盡
  • 比直接放任其panic打印的堆棧信息更精準,第一行就是發(fā)生panic的代碼行
  • 比直接放任其panic打印的堆棧信息更簡潔,可以指定信息量(kb)

最后注意,如果是啟動的多goroutine,需要在每個goroutine執(zhí)行函數(shù)的時候,寫上defer PanicHandler() 否則的話是捕獲不到其他goroutine當中的painc信息的。

總結

以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學習或者工作具有一定的參考學習價值,謝謝大家對腳本之家的支持。如果你想了解更多相關內(nèi)容請查看下面相關鏈接

您可能感興趣的文章:
  • golang panic及處理機制

標簽:曲靖 貴州 吐魯番 保定 東營 許昌 常州 德宏

巨人網(wǎng)絡通訊聲明:本文標題《Golang捕獲panic堆棧信息的講解》,本文關鍵詞  Golang,捕獲,panic,堆棧,信息,;如發(fā)現(xiàn)本文內(nèi)容存在版權問題,煩請?zhí)峁┫嚓P信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《Golang捕獲panic堆棧信息的講解》相關的同類信息!
  • 本頁收集關于Golang捕獲panic堆棧信息的講解的相關信息資訊供網(wǎng)民參考!
  • 推薦文章
    余庆县| 伊宁市| 安远县| 大英县| 乃东县| 卢龙县| 股票| 吉隆县| 临江市| 喀喇| 元氏县| 荃湾区| 麻栗坡县| 丰都县| 会东县| 阿拉尔市| 临安市| 祁东县| 沧州市| 建瓯市| 离岛区| 金坛市| 察雅县| 化隆| 申扎县| 杂多县| 四平市| 兴安盟| 元朗区| 江华| 屯门区| 钟山县| 彰化市| 台北县| 青铜峡市| 拉萨市| 鹿邑县| 长宁区| 南投县| 嘉定区| 鹤壁市|