함수를 다시 작성할 때는 다음 주의 사항을 따라야 합니다. 함수 서명은 동일하고 액세스 한정자는 기본 클래스보다 엄격할 수 없으며 재작성에는 const 또는 재정의 표시가 사용됩니다. 트랩에는 기본 클래스 함수 숨기기, 다중 재정의 및 의도하지 않은 재작성이 포함됩니다. 재정의를 올바르게 사용하고 함정을 고려하여 예기치 않은 동작을 방지하세요.
C++ 함수 재작성 주의 사항 및 함정
객체 지향 프로그래밍에서 함수 재작성은 기본 클래스에서 동일한 이름의 함수를 재정의하는 하위 클래스의 기능을 나타냅니다. 이는 강력한 메커니즘이지만 잘못 사용하면 함정이 발생할 수 있습니다.
참고:
-
함수 서명은 동일해야 합니다. 재정의된 함수는 기본 클래스 함수와 동일한 매개변수 목록 및 반환 유형을 가져야 합니다.
-
액세스 한정자는 더 엄격할 수 없습니다. 하위 클래스 함수의 액세스 한정자는 기본 클래스 함수의 액세스 한정자보다 더 엄격할 수 없습니다. 예를 들어 기본 클래스 함수가 공개인 경우 하위 클래스 함수는 보호되거나 비공개일 수 없습니다.
-
const 또는 override: const 또는 override 키워드를 사용하여 해당 함수가 새 함수를 추가하는 것이 아니라 기본 클래스 함수를 재정의한다는 점을 명확하게 나타냅니다.
-
가상 함수: 가상 함수만 재정의할 수 있습니다. 기본 클래스 함수는 virtual 키워드를 사용하여 virtual로 선언할 수 있습니다.
함정:
-
기본 클래스 함수 숨기기: 하위 클래스 함수가 기본 클래스 함수와 동일한 시그니처를 가지지만 더 느슨한 액세스 수정자를 사용하는 경우 기본 클래스 함수를 재정의하는 대신 숨깁니다.
-
다중 재정의: 함수는 단일 하위 클래스에서만 재정의될 수 있습니다. 여러 하위 클래스가 동일한 함수를 재정의하려고 하면 컴파일러에서 오류를 보고합니다.
-
의도하지 않은 재정의: 하위 클래스 함수가 기본 클래스 함수와 동일한 시그니처를 가지지만 실제로 이를 재정의하려는 의도가 아닌 경우 예기치 않은 동작이 발생할 수 있습니다.
실용 사례:
다음 기본 클래스 및 하위 클래스 예를 고려하세요.
class Base {
public:
virtual void print() const {
std::cout << "Base::print() called" << std::endl;
}
};
class Derived : public Base {
public:
void print() const override {
std::cout << "Derived::print() called" << std::endl;
}
};
로그인 후 복사
여기서 Derived 클래스는 기본 클래스의 print() 함수를 재정의하고 하위 클래스 함수는 기본 클래스 함수 및 출력을 올바르게 재정의합니다. 다른 메시지.
함정을 피하기 위한 팁:
- 재정의를 나타내려면 명시적으로 const 또는 override를 사용하세요.
- 액세스 한정자가 올바른지 확인하세요.
- 함수를 재정의하려는 경우에만 함수를 재정의하세요.
- 우발적인 재정의를 방지하려면 함수 서명을 다시 확인하세요.
위 내용은 C++ 함수 재작성 시 참고 사항 및 함정의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!