dlv使用技巧小记

dlv使用技巧小记

dlv命令说明:delve/README.md at master · go-delve/delve · GitHub

如何确定文件完整路径

在使用break时,在经过公司流水线编译后,一般不能方便的拿到源代码文件路径(locspec),比如用于类型转换的工具包"github.com/spf13/cast"内的"cast.go"源代码文件在编译后的路径就变成了"/tmp/go-build1662448535/pkg/mod/github.com/spf13/cast@v1.4.1/cast.go",其中如何获取前半部分"/tmp/go-build1662448535/pkg/mod/",阻塞了我好一会。

解决:使用sources命令

dlv attach 12345
(dlv) sources
/usr/local/go1.18.3/src/bufio/bufio.go
/usr/local/go1.18.3/src/bufio/scan.go
/usr/local/go1.18.3/src/bytes/buffer.go
/usr/local/go1.18.3/src/bytes/bytes.go
/usr/local/go1.18.3/src/bytes/reader.go
...

(dlv) sources cast
/tmp/go-build1662448535/pkg/mod/github.com/spf13/cast@v1.4.1/cast.go
/tmp/go-build1662448535/pkg/mod/github.com/spf13/cast@v1.4.1/caste.go
/tmp/go-build1662448535/pkg/mod/github.com/spf13/cast@v1.4.1/timeformattype_string.go

你的项目可能有很多package、go文件,sources 后可跟正则,可以更快的查找

某个dlv命令输出太多,标准输出放不下

我最开始使用sources命令时,没注意到sources后可以跟正则,执行sources后输出数据行数有2k+,看了下help发现 transcript 这个命令,它可以将各个命令的输出写到指定文件中

(dlv) transcript -x /home/xxx/debug/sources
(dlv) sources
(dlv) transcript -off

其中-x是标准输出就不打印了,收集完数据后,记得 transcript -off关掉

输出字符串限制

通过config -list 可以查看可以配置的选项,其中 max-string-len可以配置输出的最大字符串长度,可以根据自身情况合理设置该值

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值