在类中,如果什么都没有,则类占用1个字节,一旦类中有其他的占用空间成员,则这1个字节就不在计算之内,如一个类只有一个int则占用4字节而不是5字节。
如果只有成员函数,则还是只占用1个字节,因为类函数不占用空间
虚函数因为存在一个虚函数表,需要4个字节,数据成员对象如果为指针则为4字节,注意有字节对齐,如果为13字节,则进位到16字节空间。
一.虚函数在内存中的结构
#include <iostream>
using namespace std;
// vptr
class A {
public:
virtual void fun0() { cout << "A::fun0" << endl; }
virtual void fun1() { cout << "A::fun1" << endl; }
};
int main()
{
A a1;
cout<<sizeof(a1)<<endl;
}
二.我们再来看看继承中虚函数的内存结构,先看下面的例子
#include <iostream>
using namespace std;
class A {
public:
virtual void f() { }
};
class B {
public:
virtual void f() { }
};
class C {
public:
virtual void f() { }
};
class Drive : public A, public B, public C {
};
int main() {
Drive d;
cout << "Size is = " << sizeof(d) << endl;
return 0;
}
按照C++的约定调用顺序:从右到左的入栈顺序继承类A,B,C
#include <iostream>
using namespace std;
class Base1
{
public:
int ibase1;
Base1() : ibase1(1) {}
};
class Base2
{
public:
int ibase2;
Base2() : ibase2(2) {}
};
class Device : public virtual Base1, public virtual Base2
{
public:
int idevice;
Device() : idevice(3){}
};
int main()
{
Base1 b1;
Base2 b2;
Device d;
return 0;
}
四.同时存在虚基类和虚函数
#include <iostream>
using namespace std;
class Base
{
public:
int ibase;
virtual void f() { cout << "Base::f" << endl; }
Base() : ibase(1) {}
};
class Device1 : public virtual Base
{
public:
int idevice1;
void f() { cout << "Device1::f" << endl; }
Device1() : idevice1(2) {}
};
int main()
{
Device1 d1;
cout<<sizeof(d1)<<endl;
return 0;
}
输出:
sizeof(d1):20