满足错误接口的结构的这个 nil 实例没有显示为 nil

这应该是给某人的礼物。为什么我在这里没有得到我期望的(“错误不是零”)?


http://play.golang.org/p/s8CWQxobVL


type Goof struct {}


func (goof *Goof) Error() string {

    return fmt.Sprintf("I'm a goof")

}


func TestError(err error) {

    if err == nil {

        fmt.Println("Error is nil")

    } else {

        fmt.Println("Error is not nil")

    }

}


func main() {

    var g *Goof // nil

    TestError(g) // expect "Error is nil"

}


慕哥6287543
浏览 159回答 1
1回答

慕无忌1623718

事实证明,这是一个关于 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 mainimport "fmt"type Bob intfunc main() {    var x int = 3    var y Bob = 3    var ix, iy interface{} = x, y    fmt.Println(ix == iy)}
打开App,查看更多内容
随时随地看视频慕课网APP

相关分类

Go