>백엔드 개발 >C++ >C++ 구문 오류: 가상 상속은 생성자 초기화 목록을 사용해야 합니다. 어떻게 처리해야 합니까?

C++ 구문 오류: 가상 상속은 생성자 초기화 목록을 사용해야 합니다. 어떻게 처리해야 합니까?

WBOY
WBOY원래의
2023-08-22 11:15:431803검색

C++ 구문 오류: 가상 상속은 생성자 초기화 목록을 사용해야 합니다. 어떻게 처리해야 합니까?

C++ 프로그래밍에서 가상 상속을 사용하는 것은 다중 상속 문제를 해결하는 데 사용할 수 있는 일반적인 기술입니다. 그러나 가상 상속을 사용할 때 문제에 주의해야 합니다. 즉, 가상 상속은 생성자 초기화 목록을 사용해야 합니다. 생성자 초기화 목록을 사용하지 않으면 구문 오류가 발생하여 프로그램이 컴파일되지 않습니다. 그렇다면 우리는 이 문제를 어떻게 해결해야 할까요? 다음으로 논의해 보겠습니다.

  1. 가상 상속이 생성자 초기화 목록을 사용해야 하는 이유는 무엇입니까?

C++에서 가상 상속은 다중 상속 중 모호성 문제를 해결하는 데 사용할 수 있는 특별한 상속 방법입니다. 클래스가 두 개 이상의 기본 클래스에서 동시에 상속되는 경우 이러한 기본 클래스에 공통 상위 클래스가 있으면 파생 클래스에 여러 기본 클래스 하위 개체가 있으므로 모호성이 발생합니다. 가상 상속의 기능은 특정 클래스를 직접 또는 간접적으로 상속하는 여러 파생 클래스에 해당 클래스의 하위 개체가 하나만 포함되도록 하는 것입니다.

가상 상속을 사용하는 경우 virtual 키워드를 사용하여 기본 클래스를 가상 기본 클래스로 정의해야 합니다. 또한 파생 클래스에서 가상 기본 클래스를 초기화하려면 생성자 이니셜라이저 목록이 필요합니다. 가장 많이 파생된 클래스의 생성자가 가상 ​​기본 클래스 하위 개체의 생성을 담당하기 때문입니다. 가상 기본 클래스의 생성자가 생성자에서 명시적으로 호출되지 않으면 컴파일러는 기본적으로 가상 기본 클래스의 기본 생성자를 호출하므로 구문 오류가 발생합니다.

따라서 가상 상속은 생성자 초기화 목록을 사용해야 합니다. 그렇지 않으면 컴파일러에서 오류 메시지가 표시됩니다. 다음은 가상 상속을 사용할 때 생성자 초기화 목록을 사용하지 않음으로 인해 발생하는 구문 오류를 보여주는 샘플 프로그램입니다.

#include <iostream>
using namespace std;

class Base {
public:
    Base(int n) : num(n) {}
protected:
    int num;
};

class Derived : virtual public Base { // 虚继承
public:
    Derived(int n) {
        // 在构造函数中没有使用构造函数初始化列表
        num = n;
    }
};

int main() {
    Derived d(10);
    cout << d.num << endl;
    return 0;
}

위 프로그램에서는 가상 기본 클래스인 Base를 정의하고 Derived 클래스를 virtual로 정의합니다. Base 클래스 상속 . Derived 클래스의 생성자에서 Base 클래스는 생성자 초기화 목록을 사용하여 초기화되지 않습니다. 이로 인해 컴파일러는 "오류: 'Derived'에 대한 생성자가 기본 생성자가 없는 기본 클래스 'Base'를 명시적으로 초기화해야 합니다."라는 메시지와 함께 오류를 보고하게 됩니다.

  1. 가상 상속이 생성자 초기화 목록을 사용해야 하는 문제를 어떻게 처리하나요?

가상 상속이 생성자 초기화 목록을 사용해야 하는 문제를 해결하려면 다음과 같은 접근 방식을 취할 수 있습니다.

(1) 생성자 초기화 목록에서 가상 기본 클래스의 생성자를 명시적으로 호출

이것이 가장 일반적인 해결 방법입니다. 파생 클래스의 생성자 초기화 목록에서 가상 기본 클래스의 생성자를 명시적으로 호출하여 가상 기본 클래스 하위 개체가 올바르게 초기화되었는지 확인합니다. 이제 위 예제 프로그램에서 Derived 클래스 생성자를 수정하고 생성자 초기화 목록을 추가하여 구문 오류 문제를 해결합니다.

class Derived : virtual public Base { // 虚继承
public:
    Derived(int n) : Base(n) { // 在构造函数初始化列表中调用Base类的构造函数
        num = n;
    }
};

이렇게 하면 프로그램을 정상적으로 컴파일하고 전달할 수 있습니다.

(2) 가상 기본 클래스에 기본 생성자를 추가합니다

가상 기본 클래스에 기본 생성자가 없으면 파생 클래스에서 가상 기본 클래스의 생성자를 생성자 초기화 목록에서 명시적으로 호출해야 합니다. . 그러나 때로는 가상 기본 클래스의 소스 코드를 수정하지 못할 수도 있습니다. 이 경우 가상 기본 클래스에 기본 생성자를 추가하여 문제를 해결할 수 있습니다. 다음은 샘플 프로그램입니다.

class Base {
public:
    Base(int n) : num(n) {}
    Base() {} // 添加默认构造函数
protected:
    int num;
};

class Derived : virtual public Base { // 虚继承
public:
    Derived(int n) { // 在构造函数中不需要调用Base类的构造函数
        num = n;
    }
};

이 샘플 프로그램에서는 가상 기본 클래스 Base에 기본 생성자를 추가하므로 파생 클래스 Derived의 생성자에서 Base의 생성자를 명시적으로 호출할 필요가 없습니다. 수업 .

간단히 말하면, 가상 상속을 사용할 때 구문 오류를 방지하려면 생성자 초기화 목록을 사용하여 가상 기본 클래스를 초기화하는 데 주의해야 합니다. 가상 기본 클래스 소스 코드를 수정할 수 없는 경우 기본 생성자를 추가하여 문제를 해결할 수 있습니다.

위 내용은 C++ 구문 오류: 가상 상속은 생성자 초기화 목록을 사용해야 합니다. 어떻게 처리해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.