> 백엔드 개발 > C++ > 본문

C++ 구문 오류: 가상 멤버는 정적 또는 비정적 데이터 멤버일 수 없습니다. 어떻게 해야 합니까?

PHPz
풀어 주다: 2023-08-22 09:52:44
원래의
1024명이 탐색했습니다.

C++에서 virtual 키워드를 사용하여 함수 멤버를 정의하는 것은 해당 함수가 가상 함수이고 하위 클래스에 의해 재정의될 수 있음을 의미합니다. 그러나 데이터 멤버(즉, 속성)를 가상으로 정의하면 C++ 컴파일러는 오류를 보고합니다. 가상 멤버는 정적 또는 비정적 데이터 멤버일 수 없습니다.

그렇다면 왜 데이터 회원은 가상을 사용할 수 없나요? 가상 함수와 비가상 함수의 차이점은 가상 함수는 함수 테이블을 통해 액세스되는 반면 데이터 멤버는 직접 액세스된다는 것입니다. 데이터 멤버를 가상으로 정의하면 가상 함수를 찾을 수 없기 때문에 프로그램에서 오류가 발생합니다.

하위 클래스의 멤버 변수를 재정의해야 하는 경우에는 어떻게 해야 할까요? C++11에 도입된 새로운 기능인 가상 상속을 사용할 수 있습니다. 가상 상속은 다중 상속의 복잡성을 줄이고 일부 문제를 해결할 수 있는 특별한 상속 방법입니다. 가상 상속에서는 기본 클래스의 생성자가 한 번만 호출되므로 다중 초기화로 인해 발생하는 문제를 피할 수 있습니다.

다음은 가상 상속을 사용하여 멤버 변수 재정의를 구현하는 샘플 코드입니다.

class Base {
public:
    virtual int& getVar() { return var; }

protected:
    int var;
};

class Derived : virtual public Base {
public:
    virtual int& getVar() { return var; }

protected:
    int var;
};

int main() {
    Base* b = new Derived();
    b->getVar() = 42;
    cout << b->getVar() << endl;

    return 0;
}
로그인 후 복사

이 샘플 코드에서는 기본 클래스 Base와 파생 클래스 Derived를 정의합니다. Base 클래스에는 정수 변수 var가 있습니다. 이 변수는 이 방법으로 액세스할 수 없지만 파생 클래스에서 다시 작성하기 위한 기본 클래스로 사용할 수 있습니다. Derived 클래스에는 var라는 정수 변수도 있으며 Base의 함수를 포괄하는 Base의 getVar() 함수를 재정의합니다. 메인 함수에서 Derived의 인스턴스를 생성하고, 기본 클래스 포인터 b로 이를 가리키고, getVar() 함수를 통해 액세스합니다. 출력은 42입니다.

가상 상속을 사용하면 파생 클래스의 기본 클래스에 있는 var라는 멤버 변수를 재정의할 수 있고 이 변수의 값에 액세스하여 함수 재정의와 유사한 작업을 수행할 수 있습니다.

요약하자면 C++의 virtual 키워드는 데이터 멤버가 아닌 함수에만 사용할 수 있습니다. 하위 클래스의 멤버 변수를 재정의하려면 가상 상속을 사용할 수 있습니다. 가상 상속을 사용하면 다중 초기화 문제를 피할 수 있으며 기본 클래스의 재정의된 멤버 변수에 액세스할 수 있습니다.

위 내용은 C++ 구문 오류: 가상 멤버는 정적 또는 비정적 데이터 멤버일 수 없습니다. 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

관련 라벨:
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿