C++对象模型阅读笔记
- 默认构造函数,在下面四种情况下会生成nontrivial default constructor,这些constructor只能够满足编译器的需要,仅仅初始化base class subobject和member class object,所有其他的nonstatic member如指针、整数指针、整数数组等都不会被初始化。
- 带有“default constructor“的成员类对象
- 带有“default constructor“的基类
- “带有一个virtual function“的类
- “带有一个virtual base class“的类
- bitwise copy也就是按照位逐次拷贝(浅式复制),在下面四种情况下不会展现出。
1 .当class内含有一个member object,而后者的class声明了一个copy constructor时
- 当class继承自一个base class,而后者有一个copy constructor时
- 当class 声明了一个或者多个virtual function时
- 当class派生自一个继承串链,其中有一个或者多个virtual base class时
- copy constructor的应用,迫使编译器多多少少对程序代码做部分转化,尤其是当一个函数以传值的方式返回一个class object时,而该class有一个copy constructor时,这将导致深奥的程序转化——不论在函数的定义上或使用上。此外编译器也将copy constructor的调用操作优化,以一个额外的第一个参数取代NVR。
- 在类内部使用memcpy或者memset,只有在“class不包含任何由编译器产生的内部members“时才能有效运行。如果类内声明了一个或者以上了的virtual function,或者内含一个virtual base class,那么使用上述函数将会导致那些“被编译器产生的内部members“的初值被改写。
- 编译器会对initialization list一一处理并且可能重新排序,以反映出members的声明次序。他会安插一些代码到constructor体内,并且置于任何explicit user code之前。
- 对一个多重派生对象,将其地址指定给“最左边base class的指针“,情况和单一继承时相同,因为二者都指向相同的起始地址。需要付出的成本只有地址的指定操作而已。至于第二个或后续的base class的地址指定操作,则需要将地址修改过:加上(或减去,如果downcast的话)介于中间的base class subobjects的大小。