Methods and pointer indirection (2)

The equivalent thing happens in the reverse direction.

Functions that take a value argument must take a value of that specific type:

  1. var v Vertex
  2. fmt.Println(AbsFunc(v)) // OK
  3. fmt.Println(AbsFunc(&v)) // Compile error!

while methods with value receivers take either a value or a pointer as the receiver when they are called:

  1. var v Vertex
  2. fmt.Println(v.Abs()) // OK
  3. p := &v
  4. fmt.Println(p.Abs()) // OK

In this case, the method call p.Abs() is interpreted as (*p).Abs().

indirection-values.go

  1. package main
  2. import (
  3. "fmt"
  4. "math"
  5. )
  6. type Vertex struct {
  7. X, Y float64
  8. }
  9. func (v Vertex) Abs() float64 {
  10. return math.Sqrt(v.X*v.X + v.Y*v.Y)
  11. }
  12. func AbsFunc(v Vertex) float64 {
  13. return math.Sqrt(v.X*v.X + v.Y*v.Y)
  14. }
  15. func main() {
  16. v := Vertex{3, 4}
  17. fmt.Println(v.Abs())
  18. fmt.Println(AbsFunc(v))
  19. p := &Vertex{4, 3}
  20. fmt.Println(p.Abs())
  21. fmt.Println(AbsFunc(*p))
  22. }