1 回答
TA贡献1744条经验 获得超4个赞
事实证明,这是一个关于 Go 的常见问题,简短的回答是接口比较比较了类型和值,(*Goof)(nil)
并且error(nil)
有不同的类型。
由于if err != nil
是标准的,您需要一个可以使用它的返回值。您可以声明var err error
而不是var g *Goof
:err
的零值很方便error(nil)
或者,如果您的 func 返回error
,return nil
将返回您想要的。
有关更多背景信息,这是常见问题解答的开头:
在幕后,接口被实现为两个元素,一个类型和一个值。值,称为接口的动态值,是一个任意的具体值,类型是值的类型。对于
int
值3
,接口值示意性地包含(int, 3)
。接口值
nil
仅当内部值和类型都未设置时,(nil, nil)
。特别是,nil
接口将始终包含一个nil
类型。如果我们*int
在接口值中存储类型指针,则内部类型将*int
与指针的值无关:(*int, nil)
。因此,nil
即使内部的指针是 ,这样的接口值也将是非nil
。
并且==
严格检查类型是否相同,而不是类型(*Goof
)是否实现了接口(error
)。查看原文了解更多。
如果它有助于澄清,这不仅发生在nil
: 在这个例子中,x
和y
变量背后的数据显然是3
,但它们有不同的类型。当您将x
和y
放入interface{}
s 时,它们比较为不相等:
package main
import "fmt"
type Bob int
func main() {
var x int = 3
var y Bob = 3
var ix, iy interface{} = x, y
fmt.Println(ix == iy)
}
- 1 回答
- 0 关注
- 157 浏览
添加回答
举报