12-11继承

2017-12-12  本文已影响0人  五行猫

杂项

判断继承的层数

继承的层数要看虚表的位置被覆盖了多少回,因为构造时会从父类一层一层往下覆盖虚表,析构反之。

判断继承和成员对象的方法

观察:

  1. 虚表的个数
  2. 填写虚表的时机

总结各种情况

父类没有虚表,自身没有虚表,成员没有虚表

都没有虚表的情况下可以直接按结构体还原

父类没有虚表,子类有虚表,成员有虚表

对象的内存结构有两个虚表分别是父类和成员的,且都在子类虚表填写动作之前完成,复写1次的是成员类,复写多次的是父类

父类有虚表,自身有虚表,成员没有

内存结构中存在一个虚表,构造完父类后,移动指针构造虚表,若成员对象有构造,则构造时机在子类填写虚表动作之前,及时内联也在之前(注意流水线优化)

父类没有虚表,子类有虚表,成员有

首4字节留给子类的虚表指针,视成员对象在类中偏移而决定成员虚表指针位置,其特点是成员对象指针在子类填写虚表前填写,成员对象构造完毕后才填写子类虚表指针,特点是子类指针只构造一次,没有复写动作,内存局部结构为:

图片.png

运算符重载

在反汇编中识别为调用函数

模板

在反汇编中同样表现为函数调用,且是多处函数实现

纯虚函数

低版本中会出现19h错误

图片.png

高版本会出现 DecodePoint 标志代码

上一篇下一篇

猜你喜欢

热点阅读