Cpp 对象模型探索 / 对象的虚函数表指针的位置
生活随笔
收集整理的這篇文章主要介紹了
Cpp 对象模型探索 / 对象的虚函数表指针的位置
小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.
一、源碼
#include <iostream>class A { public:virtual void func(){};public:int count_ = 0; };int main() {std::cout << "類 A 的大小為 " << sizeof(A) << std::endl;A aobj;char *p1 = reinterpret_cast<char *>(&aobj);char *p2 = reinterpret_cast<char *>(&aobj.count_);if (p1 == p2){std::cout << "虛函數(shù)表指針位于對(duì)象的尾部。" << std::endl;}else{std::cout << "虛函數(shù)表指針位于對(duì)象的首地址處。" << std::endl;}return 0; }結(jié)果:
類 A 的大小為 16 虛函數(shù)表指針位于對(duì)象的首地址處。二、分析
? ? ? ?從上述代碼可以知道,對(duì)象 a 中存在兩個(gè)成員變量,分別是 vptr 和 i 。因?yàn)樵?linux 下,指針占 8 個(gè)字節(jié),所以對(duì)象 a 的大小為 16 。
? ? ? ?經(jīng)過(guò) p1 和 p2 兩個(gè)值的比較,發(fā)現(xiàn)二者并不相同,所以對(duì)象 a 的內(nèi)存分布如下圖所示:
(SAW:Game Over!)
總結(jié)
以上是生活随笔為你收集整理的Cpp 对象模型探索 / 对象的虚函数表指针的位置的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: 数据结构与算法 / 排序算法(1)
- 下一篇: 数据结构与算法 / 排序算法(2)