您现在的位置是:网站首页> 编程资料编程资料
go 代码的调试---打印调用堆栈的实例_Golang_
2023-05-26
394人已围观
简介 go 代码的调试---打印调用堆栈的实例_Golang_
本文介绍如何打印调用堆栈进行go代码的调试。
打印堆栈使用的runtime package中的Stack()函数
func Stack(buf []byte, all bool) int Stack formats a stack trace of the calling goroutine into buf and returns the number of bytes written to buf. If all is true, Stack formats stack traces of all other goroutines into buf after the trace for the current goroutine.
example
package main import ( "runtime" "time" "fmt" ) func main() { go power1() for { time.Sleep(time.Duration(1)*time.Minute) } } func power1(){ var buf [1024]byte fmt.Println("power1.....") n := runtime.Stack(buf[:], true) fmt.Println(string(buf[:]), n) }输出结果:
power1..... goroutine 5 [running]: main.power1() /home/lanyang/src/t.go:29 +0xec created by main.main /home/lanyang/src/t.go:14 +0x3c
goroutine 1 [sleep]: time.Sleep(0xdf8475800) /home/lanyang/src/t.go:59 +0x107 main.main() /home/lanyang/src/t.go:17 +0x4f 303
以上这篇go 代码的调试---打印调用堆栈的实例就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。
相关内容
- 我放弃Python转Go语言的9大理由(附优秀书籍推荐)_Golang_
- 深入讲解Go语言中函数new与make的使用和区别_Golang_
- golang如何利用原始套接字构造UDP包详解_Golang_
- golang方法中receiver为指针与不为指针的区别详析_Golang_
- Golang中如何使用lua进行扩展详解_Golang_
- Golang利用自定义模板发送邮件的方法详解_Golang_
- Golang实现字符串倒序的几种解决方案_Golang_
- Golang字符串变位词示例详解_Golang_
- Golang如何实现任意进制转换的方法示例_Golang_
- golang解析网页利器goquery的使用方法_Golang_
