Ym影子 2018-02-03 02:40 采纳率: 100%
浏览 926
已采纳

C++使用虚函数表跳过访问权限的做法中存留的疑惑

#include
#include
#include

using namespace std;
class demo
{
private:
virtual void print()
{
cout << "sss" << endl;
}
virtual void print2()
{
cout << "sss" << endl;
}

};

using type = void(*)(void);
int main( In int argc, In_reads(argc) Pre_z char** argv, In_z char** envp )
{
demo a1;
auto a = (type)*((int*)*(int*)(&a1));
a();

system("pause");
return 0;
}

我的问题是:为什么强制转化为(int*)而不是char*或者别的类型呢?

  • 写回答

3条回答 默认 最新

  • weixin_37744411 2018-02-03 03:50
    关注

    &a1取得对象的地址,(int*)转换为指针的地址,这个地址中存储的就是虚函数表的地址。 64位系统要用Long, 具体你可以看下面的链接:

    http://blog.csdn.net/pi9nc/article/details/11924525

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(2条)

报告相同问题?