go error 包含堆栈信息

2021-09-24 09:33:41 +08:00
 yujianwjj

大型项目中,打印 error 就是个字符串,非常难以调试,很痛苦。

我记得之前看到文章说 xerrors 的 error 包含堆栈功能会合到标准库里面,为啥现在还没有合并?

go 未来还会支持 error 中包含堆栈信息这个功能吗?

3085 次点击
所在节点    Go 编程语言
12 条回复
b00tyhunt3r
2021-09-24 09:39:11 +08:00
有啊 具体函数名忘了 你查一下 error package
SorcererXW
2021-09-24 09:40:25 +08:00
因为更好的错误处理方案一直没有定论,所以不会把一个临时解决方案合入标准库
masterclock
2021-09-24 10:04:44 +08:00
go 初始的东西,语言本身,核心概念就是凑合
go 后续的提案等等都是绝不凑合,没找到和口味的之前绝不加入新东西

用 zerolog 等 logger, 可以附带 stack trace
nanmu42
2021-09-24 10:12:44 +08:00
也许可以考虑这样的实现方式,每一层调用者在发现调用的函数返回非空 nil 后,都使用 fmt.Errorf()提供上下文后再向 return 到上一层。

例如:

```
err := client.Ping(ctx).Err()
if err != nil {
err = fmt.Errorf("redis PING: %w", err)
return nil, err
}
```

这样到了最外层(一般是打日志的时候),文本化的 err 会形如:running up: program init: redis PING: network IO timeout

在大部分情况下,我自己感觉这个都比堆栈来得实用。
xuzhzzz
2021-09-24 10:23:55 +08:00
import "github.com/pkg/errors"

errors.Wrap / errors.Wrapf
xuzhzzz
2021-09-24 10:26:20 +08:00
第一次错误出现的地方
errors.Wrap / errors.Wrapf

中间每一层都直接 return

最外一层打印
KousukeSakurako
2021-09-24 10:35:01 +08:00
在你认为应该被跟踪错误的地方不要直接 return err

可以换成
return fmt.Errorf("error can not xxx: %w", err)
hhaobao
2021-09-24 11:09:55 +08:00
https://goframe.org/pages/viewpage.action?pageId=1114255
goframe 的这个错误处理包还可以,
gerror.Wrap 包装栈信息
gerror.WrapCode 还可以带自定义的业务 api code
byx
2021-09-24 11:22:06 +08:00
zhuangzhuang1988
2021-09-24 12:17:20 +08:00
大道至简, 你不懂.
fgwmlhdkkkw
2021-09-24 18:21:10 +08:00
meiyoumingzi6
2021-09-24 21:28:25 +08:00
5 楼正解

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/803811

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX