天天看点

*(int*)&p

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

继续阅读