天天看点

C++之override关键字

概念

  • 在成员函数声明或定义中, override 确保该函数为虚函数并覆写来自基类的虚函数。
  • 使用位置在函数调用运算符之后,函数体或纯虚函数标识 “= 0” 之前。
不使用override关键字的效果
#include <iostream>
using namespace std;

class Base
{
public:
	virtual void foo() { 
	cout << "Base::foo" << endl;
	}
	virtual void goo() {
	cout << "Base::goo" << endl;
	}
};

class Derived : public Base {
public:
	void foo() { 
	cout << "Derived::foo" << endl; 
	}
	
	// 重写虚函数时将goo写成了gao,语法上编译器可以成功通过并不会报错
	void gao() { 
	cout << "Derived::goo" << endl; 
	} 
};

int main(void)
{
	Derived d;
	// Derived::foo
	d.foo();     
	// Base::goo 并非本意重写期望得到的结果
	d.goo();     
	return 0;
}
           
使用override关键字的效果
#include <iostream>
using namespace std;

class Base {
public:
    virtual void foo() {
        cout << "Base::foo()" << endl;
    }
    virtual void bar() {
        cout << "Base::bar()" << endl;
    }
    void goo() {
        cout << "Base::goo()" << endl;
    }
};

class Derived : public Base {
public:
    void foo() override {
        cout << "Derived::foo()" << endl;
    }
    
	// error: Derived::foo does not override. signature mismatch.
    void foo() const override {	
        cout << "Derived::foo()" << endl;
    }
    
	// error: Base::goo is not virtual
    void goo() override {	    
        cout << "Derived::goo()" << endl;
    }
    
	// error: 将bar误写成了bao,且基类中无名为bao的虚函数,由于使用了override,编译器会检测出此错误
    void bao() override {
        cout << "Derived::bao()" << endl;
    }
};
           

总结

  • 在派生类的成员函数中使用override时,如果基类中无此函数,或基类中的函数并不是虚函数,编译器会给出相关错误信息。
  • 养成在声明需要重写的函数后,加关键字override这样的习惯,即使不小心漏写了虚函数重写的某个苛刻条件,也可以通过编译器的报错,快速改正错误。

继续阅读