C语言中虚拟函数的内存分配机制是怎样的复杂过程?
- 内容介绍
- 文章标签
- 相关推荐
本文共计562个文字,预计阅读时间需要3分钟。
由于虚拟函数的地址翻译决定于对象的内存地址,而不是数据类型(编译器对函数+调用的合法性进行检查,决定数据类型),因此,如果类中定义了虚拟函数,则该类及其派生类和子类都必须生成对象。
因为虚拟函数的地址翻译取决于对象的内存地址,而不取决于数据类型(编译器对函数
调用的合法性检查取决于数据类型)。原来,如果类中定义了虚拟函数,该类及其派生类
就要生成一张虚函数表,即vtable。而在类的对象地址空间中存储一个该虚函数表的入口,
占4个字节,这个入口地址是在构造对象是由编译器写入的。
本文共计562个文字,预计阅读时间需要3分钟。
由于虚拟函数的地址翻译决定于对象的内存地址,而不是数据类型(编译器对函数+调用的合法性进行检查,决定数据类型),因此,如果类中定义了虚拟函数,则该类及其派生类和子类都必须生成对象。
因为虚拟函数的地址翻译取决于对象的内存地址,而不取决于数据类型(编译器对函数
调用的合法性检查取决于数据类型)。原来,如果类中定义了虚拟函数,该类及其派生类
就要生成一张虚函数表,即vtable。而在类的对象地址空间中存储一个该虚函数表的入口,
占4个字节,这个入口地址是在构造对象是由编译器写入的。

