override 지정자

재정키워드(keyword) 사용하여 기본 클래스에서 가상 함수를 재정의하는 멤버 함수를 지정할 수 있습니다.

구문

function-declaration override;

설명

재정의는 컨텍스트를 구분하며 멤버 함수 선언 후에 사용되는 경우에만 특별한 의미를 가집니다. 그렇지 않으면 예약된 키워드(keyword) 아닙니다.

예시

재정의를 사용하여 코드에서 실수로 상속 동작을 방지할 수 있습니다. 다음 예제에서는 재정의를 사용하지 않고 파생 클래스의 멤버 함수 동작이 의도되지 않았을 수 있는 위치를 보여줍니다. 컴파일러는 이 코드의 오류를 내보내지 않습니다.

class BaseClass
{
    virtual void funcA();
    virtual void funcB() const;
    virtual void funcC(int = 0);
    void funcD();
};

class DerivedClass: public BaseClass
{
    virtual void funcA(); // ok, works as intended

    virtual void funcB(); // DerivedClass::funcB() is non-const, so it does not
                          // override BaseClass::funcB() const and it is a new member function

    virtual void funcC(double = 0.0); // DerivedClass::funcC(double) has a different
                                      // parameter type than BaseClass::funcC(int), so
                                      // DerivedClass::funcC(double) is a new member function
};

재정의를 사용하면 컴파일러는 새 멤버 함수를 자동으로 만드는 대신 오류를 생성합니다.

class BaseClass
{
    virtual void funcA();
    virtual void funcB() const;
    virtual void funcC(int = 0);
    void funcD();
};

class DerivedClass: public BaseClass
{
    virtual void funcA() override; // ok

    virtual void funcB() override; // compiler error: DerivedClass::funcB() does not
                                   // override BaseClass::funcB() const

    virtual void funcC( double = 0.0 ) override; // compiler error:
                                                 // DerivedClass::funcC(double) does not
                                                 // override BaseClass::funcC(int)

    void funcD() override; // compiler error: DerivedClass::funcD() does not
                           // override the non-virtual BaseClass::funcD()
};

함수를 재정의할 수 없고 클래스를 상속할 수 없도록 지정하려면 최종 키워드(keyword) 사용합니다.

참고 항목

final 지정자
키워드