禁止虚函数被重写
class AFinal
{
public:
virtual void F1() final{}
};
class BFinal:public AFinal
{
public:
virtual void F1(){}
};
error: C3248: “AFinal::F1”: 声明为“final”的函数无法被“BFinal::F1”重写
禁止类被继承
class A final {
};
class B : public A {
};
此代码编译报错,提示不能继承A
显式声明重写 override
class A
{
public:
virtual void f1() const {}
};
class B : public A
{
public:
virtual void f1() {}
};
上面的代码在重写函数f1
时不小心漏了const
,但是编译器不会报错。因为它不知道你是要重写f1
,而认为你是定义了一个新的函数。这样的情况也发生在基类的函数签名变化时,子类如果没有全部统一改过来,编译器也不能发现问题。C++ 11
引入了override
声明,使重写更安全。
class B : public A
{
virtual void f1() override {}
};就会提示编译错误
default
class A
{
public:
A(int a){};
};
A a;会报错没有默认构造函数
此时我们增加A() = default;即可
delete
class A
{
public:
A(int a){};
};
以下操作都成功
A a(10); // OK
A b(3.14); // OK 3.14 will be converted to 3
然而,如果这不是我们想要的。我们不希望构造函数允许双类型参数,也不允许赋值工作
class A
{
public:
A(int a){};
A(double) = delete; // conversion disabled
};