在C中,你可以将函数指针放入一个void指针数组中,并将它们转换回任何类型的函数指针:
extern int (*fn1)(void);
extern void (*fn2)(int);
void foo(void)
{
void *array[2];
int i;
/* implicit cast from function pointer to void pointer */
array[0] = fn1;
array[1] = fn2;
for (i = 0; i < 2; i++)
{
int (*fp)(int, int, int);
/* implicit cast from void pointer to function pointer */
fp = array[i];
/* call function with a different signature */
fp(1, 2, 3);
}
}
我需要在Go中使用unsafe.Pointers做同样的事情。问题是:
(问题是不为什么或者我是否需要这样做;在给定的情况下,可以使用错误的参数集调用函数并错误解释返回值,因为调用者并且被监管者能够处理这个问题。)
答案 0 :(得分:3)
正如Jsor的回答所示,你可以做到这一点。请注意你可以做坏事:
package main
import (
"fmt"
"unsafe"
)
func main() {
f1 := func(s string) {}
f2 := func(i int) int { return i + 1 }
pointers := []unsafe.Pointer{
unsafe.Pointer(&f1),
unsafe.Pointer(&f2),
}
f3 := (*func(int) bool)(pointers[1]) // note, not int
fmt.Println((*f3)(1))
}
答案 1 :(得分:2)
似乎有效:
package main
import (
"fmt"
"unsafe"
"math"
)
func main() {
fn := print
faked := *(*func(float64))(unsafe.Pointer(&fn))
faked(1.0)
// For comparison
num := math.Float64bits(1.0)
print(num)
}
func print(a uint64) {
fmt.Println(a)
}
将打印
4607182418800017408
4607182418800017408
当然,您可能已经意识到尝试此操作可能存在的问题。