主页 > 知识库 > go 代码的调试---打印调用堆栈的实例

go 代码的调试---打印调用堆栈的实例

热门标签:汕头小型外呼系统 郑州亮点科技用的什么外呼系统 钉钉有地图标注功能吗 惠州电销防封电话卡 建造者2地图标注 滨州自动电销机器人排名 浙江高频外呼系统多少钱一个月 黄冈人工智能电销机器人哪个好 阿里云ai电话机器人

本文介绍如何打印调用堆栈进行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 代码的调试---打印调用堆栈的实例就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持脚本之家。

您可能感兴趣的文章:
  • Go语言用map实现堆栈功能的方法
  • Go语言的队列和堆栈实现方法
  • Python记录详细调用堆栈日志的方法

标签:昭通 泰安 晋中 泸州 驻马店 阿坝 沧州 东营

巨人网络通讯声明:本文标题《go 代码的调试---打印调用堆栈的实例》,本文关键词  代码,的,调试,---,打印,调用,;如发现本文内容存在版权问题,烦请提供相关信息告之我们,我们将及时沟通与处理。本站内容系统采集于网络,涉及言论、版权与本站无关。
  • 相关文章
  • 下面列出与本文章《go 代码的调试---打印调用堆栈的实例》相关的同类信息!
  • 本页收集关于go 代码的调试---打印调用堆栈的实例的相关信息资讯供网民参考!
  • 推荐文章