A:栈
B:堆
C:代码段(常量区)
D:数据段(静态区)
答案 : 代码段(常量区)
验证如下:
class Person
{
public:
virtual void BuyTicket() { cout << "Person::BuyTicket()" << endl; }
};
int main()
{
int a = 4;
printf("栈区:%p\n", &a);
int* c = new int;
printf("堆区:%p\n", c);
static int b = 3;
printf("静态区:%p\n", &b);
const char* d = "hello";
printf("常量区:%p\n", d);
Person ps;
printf("虚表:%p\n", *((int*)&ps));
return 0;
}
思路:比较虚函数表内存储的地址与其他存储区域的地址进行对比,看谁更接近。
通过上面的结果可以看出:虚表的地址 与 常量区的地址最为接近。
如何提取虚表的地址:首先对象第一个存储的便是虚函数表指针,因此前4个字节(32位)存储便是虚函数表的地址,
(int*)&ps 即是 _vfptr的地址, 再解引用便是 _vfptr存储的地址,即虚函数表的地址
当然:以上的结果是windows下VS2022测试的结果。
至于其他平台是否也是存储再常量区,笔者还未进行研究。