Go语言之调试

调试是一种技能,不限于我们说的debug,这只是其中的一种,这是可以打断点的调试,除此之外,还有打印输出、日志记录、单元测试,这都可以称之为调试程序的手段。

创新互联公司主营包河网站建设的网络公司,主营网站建设方案,重庆App定制开发,包河h5小程序定制开发搭建,包河网站营销推广欢迎包河等地区企业咨询


打印输出


打印输出是一种比较传统的调试手段,我们可以把我们需要了解的变量值,执行的步骤等打印出来,来证明我们的猜测,以便解决问题。


func min(a,bint)int{    //调试输出    fmt.Println("a:",a,",b:",b)    
    if a>b{ 
          return b  
  }else{                  return a  
  }
}

这是一个求最小值的函数,其中的fmt.Println("a:",a,",b:",b) 就是我们加入的调试输出语句,这样我们就可以看到被比较的两个数的值,进而推测我们求最小值的算法是否正确。


打印输出不仅可以输出数值,还可以通过测试是否有输出来判断程序走了哪个逻辑,比如if语句,可能因为比较的错误,程序进入了另外一个if分支,那么我们就可以通过使用打印输出来判断。


日志输出


这个和打印非常像,但是他比打印多了很多信息,比如发生时间,发生的代码行数等,这种尤其在我们遇到线上问题的时候尤其有用。

比如我们监控到有一些部分用户的登陆一直失败,那么我们就就可以通过我们的日志文件里的日志,来定位时间、IP、用户、错误信息以及代码行等,最终找到问题,解决问题。关于日志的适用可以参考我以前的一篇文章 http://www.flysnow.org/2017/05/06/go-in-action-go-log.html,这里就不再详细介绍了。

GDB调试


GDB是一款类Unix下的调试器,可以帮助我们调试可执行的程序,Go也对GDB进行了支持,所以我们也可以适用GDB调试go程序。


GDB是命令行的工具,在调试前,我们要先编译出我们需要调试的程序。使用go build -gcflags "-N -l" main.go即可进行编译。这里-N -l的标记是忽略编译器优化的意思,这样我们就可以更容易的调试程序。


调试通过gdb main启动,会进入一个GDB的调试界面,在这里面我们可以通过list命令查看代码,可以通过b命令对某一行打断点,可以通过run命令运行等,具体的可以参考GDB相关文档,这里不做详细介绍。


Delve调试


Delve是一个专门为调试Go程序而生的调试工具,它比GDB更强大,尤其时调试多goroutine高并发的Go程序。Delve的项目地址为https://github.com/derekparker/delve,它业绩大部分Go开发IDE选用的调试工具,比如Goland,后面我们再介绍。


Delve的使用和GDB非常像,都是命令行的工具,我们可以通过dlv debug main.go启动,然后就会进入一个交互界面,在这个界面里我们就可以进行调试操作了。


Delve的一些常用命令如下:


1.break 打断点


  1. continue 运行到断点处

  2. clear 删除断点

  3. list 显示源代码

  4. next 运行到下一行

  5. locals 打印局部变量

  6. print 打印一个变量或者表达式

  7. exit 退出调试


除此之外,还有很多,大家可以参考Delve的文档进行调试。


IDE调试


对于调试来说,命令行下的太麻烦了,所以为了工具效率,建议大家使用IDE进行调试,可见,逐行,效率高。


调试这个事情,只要可以解决我们的问题就好,有一个好的IDE可以帮助我们更高效率的调试,何乐不为呢。


这里推荐Goland,Jetbrains出品,老牌IDE厂商,非常方便。它家有很多IDE,而且快捷键都一样了,会了一个其他的也都会了。


IDE调试非常简单,点击工具栏的启动调试按钮,就可以调试了,记得提前打上断点。然后F8和F7配合就可以调试了,有专门的调试窗口可以看当前的局部变量,堆栈信息等,很简单,这里不做详细介绍了。


单元测试


单元测试也是一种调试的手段,我们可以模拟很多场景来验证我们逻辑的正确性,遇到问题,打印输出等,所以也是一种调试的手段


分享标题:Go语言之调试
文章起源:http://csdahua.cn/article/ihjchi.html
扫二维码与项目经理沟通

我们在微信上24小时期待你的声音

解答本文疑问/技术咨询/运营咨询/技术建议/互联网交流