大佬教程收集整理的这篇文章主要介绍了什么时候可以在任意结构体和 nil 之间进行相等性检查?,大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。
$ go version
go version go1.16.3 linux/amd64
任意结构体和 nil
之间的相等性检查何时可以是 true
?
考虑以下示例,我们在其中定义了一个新的 error
类型,该类型是从 valIDate()
函数返回的:
package main
import (
"log"
"strings"
)
type TestErrors []error
func (te TestErrors) Error() string {
s := make([]string,len(te))
for i,e := range te {
s[i] = e.Error()
}
return strings.Join(s,";")
}
func valIDate() error {
errs := TestErrors(nil)
log.Printf("%T",errs)
// if errs != nil {
return errs
// }
// return nil
}
func main() {
err := valIDate()
log.Printf("%T",err)
if err != nil {
log.Println("InvalID")
log.Fatal(err)
}
}
在 if errs != nil
函数的 valIDate()
检查注释掉后,if err != nil
函数中的 main()
检查将是 true
:
2021/07/14 14:37:35 main.TestErrors
2021/07/14 14:37:35 main.TestErrors
2021/07/14 14:37:35 InvalID
但是,如果我恢复注释掉的行,if errs != nil
函数中的 valIDate()
检查将失败(大概 errs
类似于 nil
,即使它是仍然被视为 main.TestErrors
类型),并且 valIDate()
将返回 nil
,导致 main()
中的测试同样失败。
那么为什么 valIDate()
函数内的检查 会失败(暗示 errs == nil
),但如果按原样返回,将在 {{ 1}}(暗示 main()
)?
暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!
如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。
小编邮箱:dio#foxmail.com (将#修改为@)
以上是大佬教程为你收集整理的什么时候可以在任意结构体和 nil 之间进行相等性检查?全部内容,希望文章能够帮你解决什么时候可以在任意结构体和 nil 之间进行相等性检查?所遇到的程序开发问题。
如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。
本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。