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的调用。