> 백엔드 개발 > C++ > C 상속에서 함수를 오버로드할 때 함수 숨김 문제를 어떻게 해결할 수 있습니까?

C 상속에서 함수를 오버로드할 때 함수 숨김 문제를 어떻게 해결할 수 있습니까?

DDD
풀어 주다: 2025-01-02 17:39:44
원래의
478명이 탐색했습니다.

How Can I Resolve Function Hiding Issues When Overloading Functions in C   Inheritance?

상속의 함수 오버로딩: 숨겨진 함수 이해

객체 지향 프로그래밍에서 상속을 사용하면 클래스가 상위 클래스의 속성과 메서드를 상속받을 수 있습니다. 그러나 기본 클래스와 파생 클래스에서 이름은 같지만 시그니처가 다른 함수를 정의하면 이름 조회가 모호해져서 오류가 발생할 수 있습니다.

문제:

다음을 고려하세요. 다음 코드 조각:

class A
{
public:
    void foo(string s){};
};

class B : public A
{
public:
    int foo(int i){};
};

class C : public B
{
public:
    void bar()
    {
        string s;
        foo(s); // Error: member function not found
    }
};
로그인 후 복사

파생 클래스 내에서 재정의된 foo 함수를 호출하려고 할 때 C의 경우 이름 조회가 파생 클래스 B에서 중지되고 기본 클래스 A에서 상속된 foo를 찾을 수 없기 때문에 컴파일러에 오류가 발생합니다.

해결책:

해결 방법 이 문제에서는 using 키워드를 사용하여 파생 클래스의 범위에서 기본 클래스의 함수를 명시적으로 선언해야 합니다. 이렇게 하면 파생 클래스 내에서 두 함수가 모두 표시됩니다.

class A
{
public:
    void foo(string s){};
};

class B : public A
{
public:
    int foo(int i){};
    using A::foo; // Re-declare function from base class
};

class C : public B
{
public:
    void bar()
    {
        string s;
        foo(s); // Now calls the inherited 'foo' function
    }
};
로그인 후 복사

설명:

상속의 이름 조회는 계층적입니다. 기본적으로 이름 조회에서는 파생 클래스에 정의된 함수의 우선 순위를 지정합니다. 위의 예에서 C에서 foo(s)가 호출되면 컴파일러는 먼저 C에서 일치하는 함수를 찾은 다음 B에서 그리고 마지막으로 A에서 일치하는 함수를 찾습니다. 그러나 B에는 자체 foo 함수가 있으므로 조회는 거기서 중지됩니다.

A::foo를 사용하여 B에서 기본 클래스의 foo 함수를 명시적으로 선언함으로써 컴파일러는 이름 조회 중에 두 함수를 모두 고려하도록 지시받습니다. 이를 통해 상속된 foo 함수를 C에서 찾고 호출할 수 있습니다.

본질적으로 이 기술은 파생 클래스에 함수가 숨어 있는 문제를 해결하고 상속 계층에서 오버로드된 함수로 작업할 때 올바른 이름 조회를 보장합니다.

위 내용은 C 상속에서 함수를 오버로드할 때 함수 숨김 문제를 어떻게 해결할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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