当基类私有派生时,编译器插入的vptr是否变为私有
Does the compiler inserted vptr becomes private when base class derived privately?
我在浏览虚拟函数和vtables时产生了疑问。假设我有如下代码:
class base
{
public:
virtual void fun(){}
};
class derived : private base
{
public:
void fun(){}
};
根据作用域规则,当基类派生为私有时,它的所有成员都将成为派生类的私有成员。编译器插入的vptr(指向vtable的指针)是否也会成为派生类的私有?
它保留了函数ptr项的vtable,尽管用private
或public
来谈论vtable是"不合适的",因为它是一个编译器细节,所以它将始终存在并为"public
"。
为了进一步扩展这一点,我不熟悉这方面的规范,但我认为(基于对来自不同编译器的大量生成的C/C++代码的汇编)禁止在虚拟环境中对函数进行单体化,即使不需要专门化(在运行时或其他情况下)。
相关文章:
- 在提升multi_index容器中,是否定义了"default index"?
- 在C++STL中是否有Polyval(Matlab函数)等价物?
- 检查输入是否不是整数或数字
- 是否可以初始化不可复制类型的成员变量(或基类)
- 在C++中,是否可以基于给定的标识符创建基类的新实例,反之亦然
- 是否可以通过C++扩展强制多个python进程共享同一内存
- 此代码是否违反一个定义规则
- 是否需要删除包含对象的"pair"?
- 是否可以从int转换为enum类类型
- 无论条件是否为true,if总是在c++中执行
- 如何找到大小'x'数组是否完全填充,在C++?
- 检查值是否在集合p1和p2中,但不在p3中
- 是否可以在编译时初始化数组,以便在运行时不会花费时间?
- 检查 std::shared_ptr<> 的当前底层类型是否为 T
- 在c++中检查长方体是否尽可能快地重叠(无迭代)
- 64位计算机上的VPTR的大小是否为64位
- vptr 是否位于对象的开头
- 当基类私有派生时,编译器插入的vptr是否变为私有
- 是否有可能在构造函数和析构函数之外修改“vptr”
- C++/编译:是否可以设置VPTR(全局vtable + 2字节索引)的大小