虚位以待(AD)
虚位以待(AD)
首页 > 软件编程 > GO语言 > go 代码的调试---打印调用堆栈的实例

go 代码的调试---打印调用堆栈的实例
类别:GO语言   作者:码皇   来源:互联网   点击:

下面小编就为大家带来一篇go 代码的调试---打印调用堆栈的实例。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧

本文介绍如何打印调用堆栈进行go代码的调试。

打印堆栈使用的runtime package中的Stack()函数

    func Stack(buf []byte, all bool) intStack 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 mainimport ( "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 +0xeccreated by main.main/home/lanyang/src/t.go:14 +0x3c
    goroutine 1 [sleep]:time.Sleep(0xdf8475800)/home/lanyang/src/t.go:59 +0x107main.main()/home/lanyang/src/t.go:17 +0x4f303

以上这篇go 代码的调试---打印调用堆栈的实例就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持脚本之家。

您可能感兴趣的文章:

  • Go语言用map实现堆栈功能的方法
  • Go语言的队列和堆栈实现方法
  • Python记录详细调用堆栈日志的方法
相关热词搜索: 调用堆栈