同一个c++类的所有实例共享一个vtable,或者每个实例都有自己的vtable
do all instances of the same c++ class share a vtable or would each one get its own?
如果Base是基类,Derived是派生类,并且有25个Derived实例,那么如何设置vtables以供所有实例访问?它们在内存中的加载位置?
编译器可以实现他们想要的动态调度。在c++中,我认为实际上根本没有任何使用vtable的要求,但发现一个没有的编译器是非常不寻常的。
在大多数情况下,我认为每个类(包含一些虚拟方法)都将拥有一个vtable(因此,如果我有5个class A
实例,我仍然只有1个vtable),但无论如何都不应该依赖这种行为。
据我所知,非虚拟类不需要vtables。
读到你的问题,你似乎认为每个对象都有自己的代码副本,我不确定,我也不想指责你这样做,但以防万一。。。
谷歌类似的内容:"c++对象在内存中是什么样子的"
内存中的某个位置将有一个vtable,可能与代码位于同一位置。该类的每个实例都将包含一个指向该类的vtable的指针,因此在您的情况下,所有25个实例都将包括一个指向vtable的一个副本的指针。
多重和虚拟继承使事情复杂化,但原理是一样的。
相关文章:
- 从C++实例化QML
- 在全局变量中保存类的实例以重新创建类(创建"backup")
- OpenGL - 在抛出"__gnu_cxx::recursive_init_error"实例后终止调用?
- 如何在c++中为模板函数实例创建快捷方式
- 在C++中,是否可以基于给定的标识符创建基类的新实例,反之亦然
- 设计一个只能由特定类实例化的类(如果可能的话,通过make_unique)
- 如何创建一个空的全局类并在启动时实例化它
- 无法创建抽象类的实例
- 多个文件的内存分配错误"在抛出 'std :: bad_alloc' what (): std :: bad_alloc 的实例后终止调用" [C++]
- 在两个类中共享相同的函数调用,并在不需要时避免空实例化
- 我收到以下错误:抛出'std::bad_alloc'实例后终止调用
- 建议在运行时将带有类实例的列表从c++导入qml
- 约束和显式模板实例化
- 通过实例理解std::move及其目的
- 为什么包含windows.h会产生语法错误,从而阻止类的实例化?(C2146,C2065)
- 有没有一种"cleaner"的方法可以在指向基的指针向量中找到派生类的第一个实例?
- 正在生成未知类实例
- 从DLL中删除类的实例
- 在std::vector上存储带有模板的类实例
- 同一个c++类的所有实例共享一个vtable,或者每个实例都有自己的vtable