• 6.10 使用闭包调试
    • 链接

    6.10 使用闭包调试

    当您在分析和调试复杂的程序时,无数个函数在不同的代码文件中相互调用,如果这时候能够准确地知道哪个文件中的具体哪个函数正在执行,对于调试是十分有帮助的。您可以使用 runtimelog 包中的特殊函数来实现这样的功能。包 runtime 中的函数 Caller() 提供了相应的信息,因此可以在需要的时候实现一个 where() 闭包函数来打印函数执行的位置:

    1. where := func() {
    2. _, file, line, _ := runtime.Caller(1)
    3. log.Printf("%s:%d", file, line)
    4. }
    5. where()
    6. // some code
    7. where()
    8. // some more code
    9. where()

    您也可以设置 log 包中的 flag 参数来实现:

    1. log.SetFlags(log.Llongfile)
    2. log.Print("")

    或使用一个更加简短版本的 where 函数:

    1. var where = log.Print
    2. func func1() {
    3. where()
    4. ... some code
    5. where()
    6. ... some code
    7. where()
    8. }

    链接

    • 目录
    • 上一节:应用闭包:将函数作为返回值
    • 下一节:计算函数执行时间