Golang 接口:理解意外的“坏错误”输出
在 Go 中,接口提供了一种机制,用于在不同的环境中定义和实现通用方法类型。然而,当接口类型定义 Error() 方法并分配给接口变量时,就会出现一种有趣的情况。
考虑以下代码片段:
type T int func (t T) Error() string { return "bad error" } func main() { var v interface{} = T(5) fmt.Println(v) // Output: "bad error", instead of "5" }
令人惊讶的是,上面的代码是“错误错误”,而不是预期的值 5。发生这种情况是因为 fmt.Println() 隐式调用 Error() 方法,如果操作数实现错误接口。
如 fmt 包文档中所述:
If an operand implements the error interface, the Error method will be invoked to convert the object to a string, which will then be formatted as required by the verb (if any).
错误接口定义了一个方法 Error(),它返回一个描述错误的字符串。当打印 v 时,它会根据 %v 格式说明符进行处理,如果存在,它会自动调用 Error() 方法。
要获得预期的输出,可以使用 Printf() 函数和适当的格式说明符,例如整数的 %d:
fmt.Printf("%d", v) // Output: "5"
总之,在将定义了 Error() 方法的类型分配给接口变量时,必须注意使用带有隐式参数格式的 Printf() 函数系列时,可能会出现意外的“错误错误”输出。
以上是当接口变量实现'error”接口时,为什么'fmt.Println”输出'bad error”而不是'5”?的详细内容。更多信息请关注PHP中文网其他相关文章!