Look at following code:
void func()
{
// ...
}
int main()
{
void (*p)();
*(int*)&p = (int)func;
(*p)();
return 0;
}
分析:
void(p)();
这行代码定义了一个指针变量p,p指向一个函数。这个函数的参数和返回值都为void。
&p是求指针变量p本身的地址。
(int)&p表示将变量p本身的地址强制类型转换成指向int类型的指针。
- ( int * )&p 表示取出这个指针里面的值,就是指针p保存的值。
(int)func表示将函数的入口地址转换成int类型的数据。
所以* ( int * )&p = (int)func,就是将函数的入口地址复制给p。所以(*p)();就是表示对函数func的调用。