我一直在从 github.com/lib/pq 阅读一些 Golang 代码,它提供了与 postgres 数据库交互的驱动程序。在我遇到的代码中:go func() { select { case <-done: _ = cn.cancel() finished <- struct{}{} case <-finished: }}()取消功能看起来像:func (cn *conn) cancel() error据我所知,下划线没有被用作关于类型的静态断言(因此编译器不会评估我所看到的任何副作用)并且它不是' t 作者可能希望丢弃它的第二个参数。总结:为什么将取消函数的结果(错误)分配给下划线?
2 回答
桃花长相依
TA贡献1860条经验 获得超8个赞
代码必须正确。为确保代码正确,代码必须可读。
Go 的第一条规则:检查错误。
func (cn *conn) cancel() error
如果我写
cn.cancel()
我是忘记检查错误还是决定丢弃错误值?
但是,如果我写
_ = cn.cancel()
我没有忘记检查错误,我确实决定丢弃错误值。
Go 编程语言规范
空白标识符
空白标识符由下划线字符 _ 表示。它用作匿名占位符而不是常规(非空白)标识符,并且在声明、操作数和赋值中具有特殊含义。
作业
空白标识符提供了一种忽略赋值中右侧值的方法:
绝地无双
TA贡献1946条经验 获得超4个赞
空白标识符“_”是一种特殊的匿名标识符。当在赋值中使用时,就像这种情况,它提供了一种显式忽略右侧值的方法。因此,开发人员决定忽略/丢弃从该方法调用返回的错误。
他们可能这样做的几个原因(基于对方法调用和上下文的快速浏览,我猜是 3 或 4):
方法调用保证在此上下文中成功。
该错误已在方法调用中得到充分处理;没有理由再次处理它。
错误无关紧要(例如,相关过程无论如何都会结束,结果将与方法调用成功且没有错误相同)。
开发人员急于让某些东西正常工作,忽略错误以节省时间,然后未能回来处理错误。
- 2 回答
- 0 关注
- 98 浏览
添加回答
举报
0/150
提交
取消