国产精品电影_久久视频免费_欧美日韩国产激情_成年人视频免费在线播放_日本久久亚洲电影_久久都是精品_66av99_九色精品美女在线_蜜臀a∨国产成人精品_冲田杏梨av在线_欧美精品在线一区二区三区_麻豆mv在线看

看透 Go 對象內部細節的神器

開發 后端
在調式 Go 程序時,我們經常想知道對象的內部數據是什么樣了,以便掌握程序的運行情況。

[[437722]]

本文轉載自微信公眾號「Golang技術分享」,作者機器鈴砍菜刀。轉載本文請聯系Golang技術分享公眾號。

在調式 Go 程序時,我們經常想知道對象的內部數據是什么樣了,以便掌握程序的運行情況。

一般有兩種做法:對于簡單的代碼測試,我們可以通過fmt包來打印一些對象信息;在稍復雜場景下,可以利用調式器來完成,例如 GDB、LLDB 和 Delve 等。

但是,這兩種做法都有不足之處。fmt包能打印的信息并不友好,尤其在結構體中含有指針對象時;通過調式器來調式程序也經常受限于各種因素,例如遠程訪問服務器。

示例

對于 fmt 包的能力短板,我們來看一個例子。

定義 instance 和 Inner 結構體,其中 instance 的C屬性字段是 Inner 類型指針。

  1. type instance struct { 
  2.  A string 
  3.  B int 
  4.  C *Inner 
  5.  
  6. type Inner struct { 
  7.  D string 
  8.  E string 

實例化一個 instance 對象ins

  1. func main() { 
  2.  ins := instance{ 
  3.   A: "AAAA"
  4.   B: 1000, 
  5.   C: &Inner
  6.    D: "DDDD"
  7.    E: "EEEE"
  8.   }, 
  9.  } 
  10.  fmt.Println(ins) 

此時,我們想知道ins的內部數據。通過fmt.Println(ins)語句得到的打印信息如下

  1. {AAAA 1000 0xc000054020} 

由于 C 字段是指針,所以打印出來的是一個地址0xc000054020,而地址背后的數據卻被隱藏了。顯然,這對程序排查非常不友好。

go-spew

go-spew 就是為了解決上述問題而生的,它為 Go 數據結構實現了一個深度打印機。

同樣以上文代碼為例,這次使用 go-spew 進行打印。

下載

  1. go get -u github.com/davecgh/go-spew/spew 

導包

  1. "github.com/davecgh/go-spew/spew" 

打印

  1. func main() { 
  2.  ins := instance{ 
  3.   A: "AAAA"
  4.   B: 1000, 
  5.   C: &Inner
  6.    D: "DDDD"
  7.    E: "EEEE"
  8.   }, 
  9.  } 
  10.  spew.Dump(ins) 

得到打印結果

  1. (main.instance) { 
  2.  A: (string) (len=4) "AAAA"
  3.  B: (int) 1000, 
  4.  C: (*main.Inner)(0xc0000ba0c0)({ 
  5.   D: (string) (len=4) "DDDD"
  6.   E: (string) (len=4) "EEEE" 
  7.  }) 

是不是非常詳細?

場景擴展

指針數組

除了結構體中含有指針對象時打印 fmt 打印不夠清晰,如果數組或者map中是指針對象時,傳統的打印同樣不友好。

  1. type Demo struct { 
  2.  a int 
  3.  b string 
  4.  
  5. func main() { 
  6.  arr := [...]*Demo{{100, "Python"}, {200, "Golang"}} 
  7.  fmt.Printf("%v\n-----------------分割線-----------\n", arr) 
  8.  spew.Dump(arr) 

兩種打印的輸出結果對比

  1. [0xc00011c018 0xc00011c030] 
  2. -----------------分割線----------- 
  3. ([2]*main.Demo) (len=2 cap=2) { 
  4.  (*main.Demo)(0xc00011c018)({ 
  5.   a: (int) 100, 
  6.   b: (string) (len=6) "Python" 
  7.  }), 
  8.  (*main.Demo)(0xc00011c030)({ 
  9.   a: (int) 200, 
  10.   b: (string) (len=6) "Golang" 
  11.  }) 

孰強孰弱,一目了然。

循環結構

通過 spew.Dump 方法可以將指針地址和它指向的數據都打印出來,那如果 go-spew 需要打印循環數據結構怎么辦,它能否正確處理(而不是陷入無限循環)?

定義循環結構體對象 Circular

  1. type Circular struct { 
  2.  a    int 
  3.  next *Circular 

實例化循環結構體對象,再分別通過 fmt 和 go-spew 進行打印對比

  1. func main() { 
  2.  c := &Circular{1, nil} 
  3.  c.next = &Circular{2, c} 
  4.  
  5.  fmt.Printf("%+v\n----------------分割線-------------------\n", c) 
  6.  spew.Dump(c) 

得到結果

  1. &{a:1 next:0xc0000962f0} 
  2. ----------------分割線------------------- 
  3. (*main.Circular)(0xc0000962e0)({ 
  4.  a: (int) 1, 
  5.  next: (*main.Circular)(0xc0000962f0)({ 
  6.   a: (int) 2, 
  7.   next: (*main.Circular)(0xc0000962e0)(<already shown>) 
  8.  }) 
  9. }) 

再次證明 go-spew 的強大。

總結

go-spew 借助于 unsafe 包,為我們帶來了非常漂亮的打印功能。

當然,go-spew 不止 Dump 方法,它也提供了其他方法,例如轉換為字符串的 Sdump 方法;輸出重定向的 Fdump 方法;與 fmt 類似的一套 Print 用法。

同時,可以通過 spew.Config 進行一些參數配置,例如設置 spew.Config.MaxDepth 用于控制打印深度。

 

調式 Go 程序時,go-spew 是一個非常好用的助手工具,推薦大家使用。

 

責任編輯:武曉燕 來源: Golang技術分享
相關推薦

2011-05-25 19:31:07

Stratus信息化

2023-08-14 08:34:14

GolangHttp

2010-10-08 10:26:45

JavaScript內

2013-03-11 09:23:22

Go語言面向對象

2021-06-02 09:23:57

Go開發內存

2024-05-14 08:47:01

JavaPAC++

2025-01-26 10:35:42

Go語言類型

2023-03-06 07:50:19

內存回收Go

2011-12-06 11:12:59

Java

2021-04-25 08:58:00

Go拍照云盤

2013-07-30 09:27:32

Go云計算語言

2013-07-30 09:23:43

VMwareGoogle云平臺

2024-10-28 11:39:30

2022-09-02 08:17:40

MapStruct代碼工具

2024-10-29 10:30:57

2011-10-08 14:09:27

JavaScript

2009-07-06 15:47:11

Servlet API

2024-11-11 10:46:05

2024-01-08 07:02:48

數據設計模式

2025-08-27 00:01:55

點贊
收藏

51CTO技術棧公眾號

亚洲jizzjizz妇女| 国产乱人伦精品一区二区| 日韩在线综合| 高清一区二区三区av| 99久久夜色精品国产亚洲96| 日本大胆欧美| 国产精品久久久久影院亚瑟| 精品久久久久国产| 欧美黄在线观看| 色是在线视频| 久久久国产一区| 色综合色综合色综合色综合色综合| 精品久久亚洲| 9国产精品视频| 91蜜桃在线免费视频| 午夜国产不卡在线观看视频| 日韩久久午夜影院| 国产999在线| 在线免费观看视频一区| 亚洲性猛交xxxxwww| 国产精品大片wwwwww| 欧美亚洲精品日韩| 国产91成人在在线播放| 国产精品手机播放| www.99热这里只有精品| av天在线观看| 精品在线观看入口| 91在线观看视频| 久久亚洲风情| 成人18视频日本| 日韩欧美在线中文字幕| vam成人资源在线观看| 欧美日一区二区三区在线观看国产免| 99精品一区二区| 精品剧情v国产在线观看在线| 国产成人一区二区三区小说| 成人午夜免费在线视频| av大片在线播放| 色喇叭免费久久综合网| 亚洲天堂中文字幕| 色中色综合影院手机版在线观看| 一区二区日本伦理| 黄色免费网站在线观看| 九一国产精品| ㊣最新国产の精品bt伙计久久| 欧美区在线播放| 国产福利片一区二区| 黄网站在线观看| 伊人久久综合影院| 亚洲欧洲精品一区二区精品久久久| 亚洲精品资源美女情侣酒店| 亚洲成a人片在线不卡一二三区| 一区二区三区中文在线| 久久999免费视频| 丰满少妇大力进入| 91成人小视频| 蜜桃一区二区三区在线| 一区二区三区四区视频在线观看| 日韩美女中文字幕| 在线播放精品一区二区三区 | 美女免费久久| 中文字幕高清20页| 欧美激情亚洲天堂| 免费影院在线观看一区| 国产成人精品视频在线| 欧美成人黑人xx视频免费观看| 日韩一区二区精品| 色综合天天天天做夜夜夜夜做| 国产精品毛片无遮挡高清| 国产黄色精品视频| 久久国产毛片| www.日本在线视频| 日韩av三区| 日韩一区二区三区电影在线观看 | 最新超碰在线| 亚洲pron| av在线影视| 一区二区三区国产免费| 国产情侣第一页| 亚洲精美视频| 精品蜜桃一区二区三区| 国产精品678| 欧美性受xxxx白人性爽| 欧美剧在线观看| 一区二区三区精品99久久| 亚洲国产成人精品久久| 日韩欧美在线观看一区二区三区| 欧美性xxxxxx| 午夜视频在线观看一区二区| 又黄又www| 久久精品99久久无色码中文字幕| 岛国av一区二区| 在线免费毛片| 污视频网站观看| 国产午夜亚洲精品不卡| av免费观看网| 在线日韩一区| 亚洲国产日韩av| 永久久久久久| 亚洲电影二区| 一本久久精品一区二区 | 亚洲欧洲精品一区二区三区波多野1战4 | 日日夜夜免费精品视频| 欧美区亚洲区| 亚洲欧美在线专区| 亚洲精品一二三区区别| 香蕉av一区二区| 99re66热这里只有精品8| 欧美性感美女一区二区| 成人在线免费观看91| 成人激情在线| 成人在线视频免费观看| 欧美大黑bbbbbbbbb在线| 亚洲一本二本| 99热这里只有精品8| 免费视频一区| 久久国产生活片100| 国产一区二三区好的| 精品视频在线一区| 色噜噜亚洲精品中文字幕| 三级免费网站| 欧美日韩亚洲一区二区三区四区| 精品国产免费久久久久久尖叫| 国产一区在线观| 亚洲精品成人久久久998| 最新国产精品久久| 青青草成人免费在线视频| 免费无码不卡视频在线观看| 色悠悠久久综合网| 米奇.777.com| 国内精品一区视频| 丝袜美女在线观看| 成人欧美一区二区三区的电影| 久久爱.com| 欧美重口另类| 欧美xxxxx视频| 一本色道久久综合亚洲精品高清| 美女视频一区二区三区| 不卡高清视频专区| 国产精品美女久久久久久久久| 亚洲成人综合视频| 91精品国产色综合久久| 亚洲欧美制服第一页| 九九视频直播综合网| 国产精品久久久久久久久粉嫩av| 成人欧美一区二区三区视频| 日韩av一区二区三区在线| 国产女教师bbwbbwbbw| 国产精品最新在线观看| 亚洲美女色禁图| 国产精品成人va在线观看| 免费涩涩18网站入口| 黄视频网站在线观看| 日韩精品一区二区三区四区| 爱情岛论坛亚洲品质自拍视频网站| 亚洲精品国产精品国产自| 韩国美女久久| 在线不卡国产精品| 久久精品色综合| 久久久最新网址| 日韩在线观看| 欧美日韩亚洲综合一区二区三区激情在线| 美女视频第一区二区三区免费观看网站| 欧美va日韩va| www.久久99| 亚洲综合第一页| 久久夜色精品| 久久久久久久中文| 亚洲男人电影天堂| а天堂8中文最新版在线官网| 日韩精品免费看| 高潮久久久久久久久久久久久久| 色综合综合网| 久久乐国产精品| 欧美激情一区| 经典三级在线视频| 洋洋av久久久久久久一区| 国产秀色在线www免费观看| 中文字幕日韩欧美| 先锋资源久久| 日本一道在线观看| 日韩欧美在线一区| 男人的天堂免费在线视频| 欧美多人爱爱视频网站| 北条麻妃国产九九九精品小说| 亚洲国产精品久久久久久女王| 久久久五月婷婷| 亚洲欧洲成人| 日韩在线视频网站| 日本一本不卡| 中文字幕一区二区三区四区五区人| 亚洲视频在线一区观看| 成人免费网址| 国产精品高潮在线| 一区二区三区高清视频在线观看| 粗暴91大变态调教| 欧美日本韩国一区二区三区视频| 先锋影音国产精品| 亚洲成av人影院| 国产美女高潮在线|