摘要: C++对象模型中加入多继承从单继承可以知道,派生类中只是扩充了基类的虚函数表。如果是多继承的话,又是如何扩充的?1)每个基类都有自己的虚表。2)子类的成员函数被放到了第一个基类的表中。3)内存布局中,其父类布局依次按声明顺序排列。4)每个基类的虚表中的print()函数都被overwrite成了子类... 阅读全文
posted @ 2015-07-24 15:19 stemon 阅读(312) 评论(0) 推荐(0) 编辑
摘要: 在开始之前,首先科普一下cout指针的知识,这样才能在测试程序中很好的理解:看下面的代码:void main(void){ int a = 10; int *p = &a; cout << a << endl; cout << p << endl; cout << *p << endl; cout ... 阅读全文
posted @ 2015-07-24 15:00 stemon 阅读(505) 评论(0) 推荐(0) 编辑
摘要: 有重写的单继承派生类中重写了基类的print()函数。//Derived_Overwrite.h#pragma once#include "base.h"class Derived_Overrite : public Base{public: Derived_Overrite(int); ... 阅读全文
posted @ 2015-07-24 11:27 stemon 阅读(234) 评论(0) 推荐(0) 编辑
摘要: C++对象模型中加入单继承不管是单继承、多继承,还是虚继承,如果基于“简单对象模型”,每一个基类都可以被派生类中的一个slot指出,该slot内包含基类对象的地址。这个机制的主要缺点是,因为间接性而导致空间和存取时间上的额外负担;优点则是派生类对象的大小不会因其基类的改变而受影响。如果基于“表格驱动... 阅读全文
posted @ 2015-07-24 09:44 stemon 阅读(354) 评论(0) 推荐(0) 编辑
摘要: 如何访问成员?前面介绍了C++对象模型,下面介绍C++对象模型的对访问成员的影响。其实清楚了C++对象模型,就清楚了成员访问机制。下面分别针对数据成员和函数成员是如何访问到的,给出一个大致介绍。对象大小问题其中:3个类中的函数都是虚函数lDerived继承BaselDerived_Virtual虚继... 阅读全文
posted @ 2015-07-24 02:28 stemon 阅读(236) 评论(0) 推荐(0) 编辑