Go语言之调试

简介: 调试是一种技能,不限于我们说的debug,这只是其中的一种,这是可以打断点的调试,除此之外,还有打印输出、日志记录、单元测试,这都可以称之为调试程序的手段。打印输出打印输出是一种比较传统的调试手段,我们可以把我们需要了解的变量值,执行的步骤等打印出来,来证明我们的猜测,以便解决问题。

调试是一种技能,不限于我们说的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 打断点


  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配合就可以调试了,有专门的调试窗口可以看当前的局部变量,堆栈信息等,很简单,这里不做详细介绍了。


单元测试


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


相关实践学习
阿里云图数据库GDB入门与应用
图数据库(Graph Database,简称GDB)是一种支持Property Graph图模型、用于处理高度连接数据查询与存储的实时、可靠的在线数据库服务。它支持Apache TinkerPop Gremlin查询语言,可以帮您快速构建基于高度连接的数据集的应用程序。GDB非常适合社交网络、欺诈检测、推荐引擎、实时图谱、网络/IT运营这类高度互连数据集的场景。 GDB由阿里云自主研发,具备如下优势: 标准图查询语言:支持属性图,高度兼容Gremlin图查询语言。 高度优化的自研引擎:高度优化的自研图计算层和存储层,云盘多副本保障数据超高可靠,支持ACID事务。 服务高可用:支持高可用实例,节点故障迅速转移,保障业务连续性。 易运维:提供备份恢复、自动升级、监控告警、故障切换等丰富的运维功能,大幅降低运维成本。 产品主页:https://www.aliyun.com/product/gdb
目录
相关文章
|
10天前
|
Go
go语言中的数据类型
go语言中的数据类型
11 0
|
15天前
|
Go 开发者
掌握Go语言:Go语言结构体,精准封装数据,高效管理实体对象(22)
掌握Go语言:Go语言结构体,精准封装数据,高效管理实体对象(22)
|
15天前
|
安全 Go
掌握Go语言:Go语言通道,并发编程的利器与应用实例(20)
掌握Go语言:Go语言通道,并发编程的利器与应用实例(20)
|
15天前
|
存储 缓存 安全
掌握Go语言:Go语言中的字典魔法,高效数据检索与应用实例解析(18)
掌握Go语言:Go语言中的字典魔法,高效数据检索与应用实例解析(18)
|
16天前
|
Go
使用Go语言发邮件
使用Go语言发邮件
20 2
|
27天前
|
缓存 安全 Java
Go语言小细节
Go语言小细节
36 0
|
1月前
|
存储 安全 Go
|
1月前
|
安全 编译器 Go
Go语言中的int和int32:同一个概念吗?
【2月更文挑战第24天】
55 3
|
15天前
|
存储 安全 Go
掌握Go语言:Go语言类型转换,无缝处理数据类型、接口和自定义类型的转换细节解析(29)
掌握Go语言:Go语言类型转换,无缝处理数据类型、接口和自定义类型的转换细节解析(29)
|
9天前
|
存储 Java 编译器
go语言基础语法
go语言基础语法