首页 >后端开发 >Golang >为什么对于自定义类型,'fmt.Println()”更喜欢'Error()”而不是'String()”?

为什么对于自定义类型,'fmt.Println()”更喜欢'Error()”而不是'String()”?

Patricia Arquette
Patricia Arquette原创
2024-11-27 04:20:13579浏览

Why Does `fmt.Println()` Prefer `Error()` Over `String()` for Custom Types?

为什么 Error() 方法会覆盖 fmt.Println() 中的 String() 方法

当你同时实现 String() 和 Error 时对于自定义类型的 () 方法,您可能会遇到 fmt.Println() 优先考虑 Error() 方法而不是 String() 的情况

这是因为 fmt 包在选择调用哪个方法来格式化对象时采用层次结构。根据包文档,应用以下操作顺序:

  1. 如果对象实现了 Formatter 接口,则将调用其 Format() 方法。
  2. 如果 %#使用 v 格式且对象实现了 GoStringer 接口,则会调用其 GoString() 方法。
  3. 如果对象实现了 error 接口,则其Error() 方法将用于将对象转换为字符串。
  4. 如果对象实现了 String() 方法,则会调用其 String() 方法。

因为在此层次结构中,错误接口的排名高于 String() 接口,如果给定对象实现了这两种方法,则 fmt.Println() 将优先考虑 Error() 方法。这是因为错误通常需要更紧急的关注,并且应该以清晰简洁的方式及时传达。

在提供的示例中,Person 类型实现了 String() 和 Error() 方法。但是,Error() 方法仅返回字符串“Failed”,而 String() 方法则提供有关此人的更丰富的信息描述。当您使用 fmt.Println() 打印出 Person 类型的实例时,您只会看到“失败”消息,因为由于上述层次结构,Error() 方法优先于 String() 方法。

以上是为什么对于自定义类型,'fmt.Println()”更喜欢'Error()”而不是'String()”?的详细内容。更多信息请关注PHP中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn