Go语言实战笔记(二十三)| Go 调试

《Go语言实战》读书笔记,未完待续,欢迎扫码关注公众号flysnow_org或者网站http://www.flysnow.org/,第一时间看后续笔记。觉得有帮助的话,顺手分享到朋友圈吧,感谢支持。

对于任何程序员来说,调试程序是必备的技能。当我们的开发好的程序不符合我们的预期时,就需要我们通过调试它找到根本的原因,然后才可以有针对性的解决它。

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

打印输出

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

func min(a,b int) 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 打断点 2. continue 运行到断点处 3. clear 删除断点 4. list 显示源代码 5. next 运行到下一行 6. locals 打印局部变量 7. print 打印一个变量或者表达式 8. exit 退出调试

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

IDE调试

对于调试来说,命令行下的太麻烦了,所以为了工具效率,建议大家使用IDE进行调试,可见,逐行,效率高。 调试这个事情,只要可以解决我们的问题就好,有一个好的IDE可以帮助我们更高效率的调试,何乐不为呢。

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

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

单元测试

单元测试也是一种调试的手段,我们可以模拟很多场景来验证我们逻辑的正确性,遇到问题,打印输出等,所以也是一种调试的手段,具体关于Go的单元测试可以参考http://www.flysnow.org/2017/05/16/go-in-action-go-unit-test.html这篇文章,这里不再详细介绍。

调试是手段,也算一种技能,以解决问题为目的,只要可以解决问题,就是好的调试手段。

《Go语言实战》读书笔记,未完待续,欢迎扫码关注公众号flysnow_org或者网站http://www.flysnow.org/,第一时间看后续笔记。觉得有帮助的话,顺手分享到朋友圈吧,感谢支持。

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏九彩拼盘的叨叨叨

node.js 第三方模块

46330
来自专栏Android开发经验

让你的App有声音

12120
来自专栏Janti

你可以这么理解五种I/O模型

因为项目需要,接触和使用了Netty,Netty是高性能NIO通信框架,在业界拥有很好的口碑,但知其然不知其所以然。

21150
来自专栏达观数据

达观数据应对大规模消息数据的处理经验

达观数据是为企业提供大数据处理、个性化推荐系统服务的知名公司,在应对海量数据处理时,积累了大量实战经验。其中达观数据在面对大量的数据交互和消息处理时,使用了称为...

38480
来自专栏杨建荣的学习笔记

sysbench压测小记(r11笔记第99天)

对于很多线上业务而言,如果有新服务器,新的环境,新的业务,到底资源和预期的承载压力是否匹配,这个得用数据说话,或是通过严谨的论证来阐述。 比如一台新...

51560
来自专栏一枝花算不算浪漫

【python】Python 资源大全中文版

70720
来自专栏友弟技术工作室

Python 资源大全中文版

GitHub 上有一个 Awesome - XXX 系列的资源整理,资源非常丰富,涉及面非常广。awesome-python 是 vinta 发起维护的 Pyt...

1.1K60
来自专栏DOTNET

.Net多线程编程—预备知识

1 基本概念 共享内存的多核架构:一个单独的封装包内封装了多个互相连接的未处理器,且所有内核都可以访问主内存。共享内存的多核系统的一些微架构,例如内核暂停功能,...

377110
来自专栏JAVA技术zhai

通过Java 线程堆栈进行性能瓶颈分析

改善性能意味着用更少的资源做更多的事情。为了利用并发来提高系统性能,我们需要更有效的利用现有的处理器资源,这意味着我们期望使 CPU 尽可能出于忙碌状态(当然,...

393110
来自专栏微服务生态

利用多写Redis实现分布式锁原理与实现分析

在我写这篇文章的时候,其实我还是挺纠结的,因为我这个方案本身也是雕虫小技拿出来显眼肯定会被贻笑大方,但是我最终还是拿出来与大家分享,我本着学习的态度和精神,希望...

16630

扫码关注云+社区

领取腾讯云代金券