Go 教程中提到指针用于实现值上的方法。但是,如果我们声明一个带有非指针接收器的方法,但尝试在指针值上使用它,或者反之亦然,会发生什么?
答案在于 Go 语言的两个基本规则:
方法派生:
Go 允许从现有方法派生方法。在您的示例中,方法 func (v Vertex) Abs() float64 派生自方法 func (v *Vertex) Abs() float64。这意味着当你声明前一个方法时,会自动生成一个新的实现,它本质上是用指向接收者的指针来调用原始方法:
func (v *Vertex) Abs() float64 { return math.Sqrt(v.X*v.X+v.Y*v.Y) } func (v Vertex) Abs() float64 { return Vertex.Abs(*v) } // Automatically generated
因此,无论你是否声明 func (v * Vertex) Abs() 或 func (v Vertex) Abs(),这两种情况都会调用生成的方法。
自动寻址取:
Go 可以自动生成一个指向变量的指针。在以下情况下,表达式 v.Abs() 解析为代码:
vp := &v vp.Abs()
这意味着当您将值传递给需要指针的方法时,Go 无法自动从指针派生该方法现有的,编译器会生成一个指向该值的指针,然后调用该指针上的方法。
总而言之,Go 遵循以下规则来处理指针和方法:
以上是当接收者类型和值类型不匹配时,Go 如何处理方法和指针?的详细内容。更多信息请关注PHP中文网其他相关文章!