函数地址指向函数本身的内存地址,而指针指向变量或结构的内存地址。然而,函数地址也可以存储在指针中,使我们能够通过指针调用函数。这些概念在各种场景中很有用,例如动态调用函数或创建回调函数。
Go中的函数地址与指针:微妙的关系
Go语言中,函数地址和指针看似相近,但它们之间却存在着微妙的区别。理解它们的差异对于编写高效且可维护的代码至关重要。
函数地址
函数地址是指向函数本身内存位置的地址。它可以通过编译器生成的 func
字面字或 reflect
包中的 ValueOf
或 Func
函数获取。
指针
指针是一个存储另一个值地址的变量。在Go中,指针可以通过 *
符号和类型名称声明。例如,*int
是一个指向整数值的指针。
它们之间的关系
函数地址和指针指向不同的东西。函数地址指向函数本身的内存地址,而指针指向变量或结构的内存地址。但是,函数地址也可以存储在指针中。
在以下示例中:
func myFunc() {}
var fptr = &myFunc
fptr
是一个指针,指向函数 myFunc
的地址。这使我们能够通过指针调用函数:
(*fptr)() // 等同于 myFunc()
实战案例
函数地址和指针在各种场景中很有用。以下是一个利用这些概念的实用案例:
package main
import (
"fmt"
"math"
)
// 计算半径的函数
func radius(n int) float64 {
return float64(n) / 2.0
}
// 求一个数字的根的函数
func sqrt(n int) float64 {
return math.Sqrt(float64(n))
}
var operations = map[string]func(int) float64{
"radius": radius,
"sqrt": sqrt,
}
func main() {
input := "sqrt"
num := 9
// 通过名称获取函数指针
op := operations[input]
// 调用函数并打印结果
fmt.Println(op(num))
}
此示例演示了如何将函数地址存储在字典中,并在运行时通过函数名称动态调用它们。