Go语言之调试

本文涉及的产品
日志服务 SLS,月写入数据量 50GB 1个月
简介: 调试是一种技能,不限于我们说的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
目录
相关文章
|
7天前
|
存储 前端开发 Go
Go语言中的数组
在 Go 语言中,数组是一种固定长度的、相同类型元素的序列。数组声明时长度已确定,不可改变,支持多种初始化方式,如使用 `var` 关键字、短变量声明、省略号 `...` 推断长度等。数组内存布局连续,可通过索引高效访问。遍历数组常用 `for` 循环和 `range` 关键字。
|
8天前
|
Go 调度 开发者
Go语言中的并发编程:深入理解与实践###
探索Go语言在并发编程中的独特优势,揭秘其高效实现的底层机制。本文通过实例和分析,引导读者从基础到进阶,掌握Goroutines、Channels等核心概念,提升并发处理能力。 ###
|
4天前
|
存储 安全 算法
Go语言是如何支持多线程的
【10月更文挑战第21】Go语言是如何支持多线程的
101 72
|
4天前
|
安全 大数据 Go
介绍一下Go语言的并发模型
【10月更文挑战第21】介绍一下Go语言的并发模型
24 14
|
3天前
|
安全 Go 开发者
go语言并发模型
【10月更文挑战第16天】
18 8
|
4天前
|
Java 大数据 Go
Go语言:高效并发的编程新星
【10月更文挑战第21】Go语言:高效并发的编程新星
17 7
|
3天前
|
安全 Java Go
go语言高效切换
【10月更文挑战第16天】
12 5
|
3天前
|
运维 监控 Go
go语言轻量化
【10月更文挑战第16天】
10 3
|
3天前
|
安全 Go 调度
Go语言中的并发编程:解锁高性能程序设计之门####
探索Go语言如何以简洁高效的并发模型,重新定义现代软件开发的边界。本文将深入剖析Goroutines与Channels的工作原理,揭秘它们为何成为实现高并发、高性能应用的关键。跟随我们的旅程,从基础概念到实战技巧,一步步揭开Go并发编程的神秘面纱,让您的代码在多核时代翩翩起舞。 ####
|
4天前
|
Go 调度 开发者
Go语言多线程的优势
【10月更文挑战第15天】
10 4