Go入门指南系列-VI-X-使用闭包调试
当您在分析和调试复杂的程序时,无数个函数在不同的代码文件中相互调用,如果这时候能够准确地知道哪个文件中的具体哪个函数正在执行,对于调试是十分有帮助的。您可以使用 runtime
或 log
包中的特殊函数来实现这样的功能。包 runtime
中的函数 Caller()
提供了相应的信息,因此可以在需要的时候实现一个 where()
闭包函数来打印函数执行的位置:
1 | where := func() { |
您也可以设置 log
包中的 flag
参数来实现:
1 | log.SetFlags(log.Llongfile) |
或使用一个更加简短版本的 where()
函数:
1 | var where = log.Print |
链接
- 目录
- 上一节:应用闭包:将函数作为返回值
- 下一节:计算函数执行时间