重写C++11中析构函数后的标识符
Override identifier after destructor in C++11
虚拟析构函数声明后的重写标识符有什么特殊含义吗?
class Base
{
public:
virtual ~Base()
{}
virtual int Method() const
{}
};
class Derived : public Base
{
public:
virtual ~Derived() override
{}
virtual int Method() override // error: marked override, but does not override - missing const
{}
};
在虚拟方法上使用重写标识符非常有用:当基本虚拟方法实际未被重写时,编译器将报告错误。
对虚拟析构函数的重写也有任何意义/功能吗?
是。如果基本析构函数不是虚拟的,那么override
标记将导致程序不编译:
class Base
{
public:
~Base()
{}
};
class Derived : public Base
{
public:
virtual ~Derived() override //error: '~Derived' marked 'override' but does
// not override any member functions
{}
};
具有特殊意义的不是override
,而是析构函数本身:
10.3虚拟功能
6/即使析构函数不是继承的类重写声明为虚拟的基类析构函数;见12.4和12.5.
如果您将此与前面的条款结合使用:
5/如果虚拟函数标记有virt说明符override和不重写基类的成员函数,该程序不正规。[示例:
struct B { virtual void f(int); }; struct D : B { void f(long) override; // error: wrong signature overriding B::f void f(int) override; // OK };
--结束示例]
您可以看到,如果一个析构函数被标记为override
,但基类没有virtual
析构函数,则该程序是格式错误的。
相关文章:
- 什么时候调用组成单元对象的析构函数
- 如果C++类在类方法中具有动态分配,但没有构造函数/析构函数或任何非静态成员,那么它仍然是POD类型吗
- 内联映射初始化的动态atexit析构函数崩溃
- 什么时候调用析构函数
- 优先顺序:智能指针和类析构函数
- C++-明确何时以及如何调用析构函数
- 使用基类指针创建对象时,缺少派生类析构函数
- 在c++中使用向量时,如何调用构造函数和析构函数
- 重载运算符new[]的行为取决于析构函数
- 我需要知道编译器如何在cpp中使用析构函数
- 为什么在使用转换构造函数赋值后调用C++类的析构函数?
- 析构函数调用
- 通过引用传递-为什么要调用这个析构函数
- 对具有动态分配的内存和析构函数的类对象的引用
- 重载 -> shared_ptr 个实例中的箭头运算符<interface>,接口中没有纯虚拟析构函数
- C++成员的析构函数顺序与shared_ptr
- C++ 防止在映射中放置()时调用析构函数
- 在这种情况下显式调用时,std::cout 如何更改析构函数的行为?
- 调用析构函数以释放动态分配的内存
- 重写C++11中析构函数后的标识符