在此示例中,为什么视觉工作室编译器允许违反私人继承
Why does Visual Studio compiler allow violation of private inheritance in this example?
我在Visual Studio 2013和2017中发现std::unique_ptr
的行为非常奇怪。让我们考虑一个示例:
class Base
{
public:
virtual ~Base() = default;
virtual void Foo() = 0;
};
class Derived : private Base
{
public:
void Foo() override
{
std::cout << "Foo";
}
};
void Foo(std::unique_ptr<Base> a)
{
a->Foo();
}
Foo(std::unique_ptr<Base>(new Derived())); // Compiles
请注意,继承是私人的。此示例仅在Visual Studio上编译。此外,虚拟函数调用有效,因为它是公共继承。因此,我们违反了封装违规行为,因为从Derived
到Base
的演员表应该无法访问。有人可以解释为什么Visual Studio允许这样做吗?这是一个已知问题吗?
下面的行没有为合理原因编译。第一个用法和第二个用法之间的唯一区别是在第二个用法中,创建了命名对象B
。
std::unique_ptr<Base> B(new Derived()); // Doesn't compile
它是否以某种方式与仍未解决的问题相关?
这是在cl
版本中修复的19.15.26726(VS 2017 v15.9.0-pre.1.0(:
Foo(std::unique_ptr<Base>(new Derived()));
给出
error C2243: 'type cast': conversion from 'Derived *' to 'Base *' exists, but is inaccessible
相关文章:
- C/C++编译器通常会删除重复的库吗
- 模板-模板参数推导:三个不同的编译器三种不同的行为
- Win32编译器选项和内存分配
- MSVC多行宏编译器错误
- 静态数据成员的问题-修复链接错误会导致编译器错误
- 此代码是否违反一个定义规则
- C++,我收到一个无法理解的编译器错误
- 在线编译器中的分段C++没有打印消息
- 如何解决gcc编译器优化导致的centos双编译器设置中的分段错误
- C/C++预处理器是否可以检测一些编译器选项
- 是否有C++编译器选项允许激进地删除所有函数调用,并将参数传递给具有空体的函数
- C++错误C2600:无法定义编译器生成的特殊成员函数(必须首先在类中声明)
- 我需要知道编译器如何在cpp中使用析构函数
- 编译器如何区分std::vector的构造函数
- CLANG 编译器 说:变量"PTR"可能未初始化
- 告诉c++编译器该参数没有别名
- 使用仅使用一次的变量调用的复制构造函数.这可能是通过调用move构造函数进行编译器优化的情况吗
- 违反严格别名并不总是会产生编译器警告
- 在此示例中,为什么视觉工作室编译器允许违反私人继承
- visual studio 2013 - x86/ c++ -指针指向指针:Const被编译器违反