iOS 程序员 写 Go 遇到了 这样的问题 看 Go 社区部分支持 print 部分支持 devel 搜了点资料,说 go 并行 不适合断点调试
能有大佬解释下 print 和 delve 的利弊吗
1
TypeErrorNone 2017-08-31 18:16:22 +08:00
m
|
2
monsterxx03 2017-08-31 18:21:01 +08:00
简单问题 print, 复杂的 devel, devel 可以调试当前运行的所有 goroutine 啊,就像 gdb 调试多线程程序一样,该用就用,也没啥利弊的。
|
3
nadoo 2017-08-31 18:40:19 +08:00
因为之前 windows 下没有好的 debug 工具,所以就习惯了曾经鄙视的 print 的方式,不搞复杂的程序感觉够用
|
4
jarlyyn 2017-08-31 18:52:59 +08:00 via Android
断点 辅日志。
|
5
jameshuazhou 2017-08-31 19:00:31 +08:00
在开发的时候,加大量的 log
|
6
hantsy 2017-08-31 20:11:43 +08:00
我非常奇怪,Go 没测试框架吗?
|
7
gouchaoer 2017-08-31 20:19:44 +08:00 via Android
没法断点调试,不可能吧
|
8
abujj 2017-08-31 20:21:32 +08:00 via Android
经过写了一年的经历告诉你。几乎盲写,然后运行 。debug 几乎不能用 有时候变量值根本怼不出来。log 才是王道
|
9
pubby 2017-08-31 20:28:14 +08:00
以前 emacs 写用 log,现在 Gogland 写还是 log -_-
|
10
xrlin 2017-08-31 20:31:28 +08:00
写 log, 偶尔用 Gogland 的 debug 功能。
|
11
owt5008137 2017-08-31 21:32:40 +08:00 via Android
好像之前有人贴过一个类似 gdb 的东东。忘记叫什么了。当时主要目标是 go 的 coredump,你可以搜搜看
|
12
mifly 2017-08-31 21:56:05 +08:00
一般 print 日志,复杂的用 Delve
Gogland 自带 delve 调试,还是很好用的 |
13
HarrisonZ 2017-08-31 22:08:16 +08:00
gogland 打断点一直很好用,vscode 安装 godebug 之后也可以实现断点。只不过你要清楚你的断点是在哪个 gorutine 里面
|
14
wweir 2017-08-31 22:33:29 +08:00 1
print 调试,日志做好分级
绝大部分的调试工具,在分布式场景下,毫无作为。只有张弛有度、串联有序的日志,才是最好的帮手 |
15
BBCCBB 2017-09-01 10:37:08 +08:00
打日志,完备的日志,不管是调试,还是运行出错找错,都是极好的
|
16
BiuBiuBiuX OP @wweir 为什么 “绝大部分的调试工具,在分布式场景下,毫无作为” 可以举个例子吗...?
|
17
wweir 2017-09-01 14:54:06 +08:00
@BiuBiuBiuX 分布式场景里充斥着心跳、超时、远程调用,这些东西严重依赖时序。
而想要通过调试工具来分析,很大程度上依赖于把程序停下来,分析、控制当时程序内部的状态。 一旦停下来,程序的很多表现就和一直跑着时有很大区别了。 如果说不停下来,仅仅作为一层监控,那 log 更加合适 我说的不是很好,可以搜一下相关的关键字 |
18
Muninn 2017-09-26 11:12:13 +08:00 1
vscode 大法好
自带 delve 啊 虽然 atom 也带 我就是因为 atom 崩溃投奔 vscode 了 发现 vscode 各种好 到处安利 |
19
BiuBiuBiuX OP @Muninn 最后用了 Goland ... 公司是微服务 vscode 貌似不能一个窗口同时 debug 多个 go
|