• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    go 代码的调试---打印调用堆栈的实例

    本文介绍如何打印调用堆栈进行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记录详细调用堆栈日志的方法
    上一篇:我放弃Python转Go语言的9大理由(附优秀书籍推荐)
    下一篇:Go语言中的延迟函数defer示例详解
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯 版权所有

    《增值电信业务经营许可证》 苏ICP备15040257号-8

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