> 백엔드 개발 > C++ > 오버로드된 함수를 std::for_each()에 전달할 때 모호성을 해결하는 방법은 무엇입니까?

오버로드된 함수를 std::for_each()에 전달할 때 모호성을 해결하는 방법은 무엇입니까?

Linda Hamilton
풀어 주다: 2024-12-17 07:00:26
원래의
1001명이 탐색했습니다.

How to Resolve Ambiguity When Passing Overloaded Functions to std::for_each()?

오버로드된 함수를 std::for_each()에 전달

C에서 오버로드된 함수로 작업할 때 다음이 필요한 상황에 직면할 수 있습니다. 이러한 오버로드 중 하나를 std::for_each()와 같은 알고리즘에 전달합니다. 그러나 컴파일러는 반복기의 유형에 따라 호출할 올바른 오버로드를 자동으로 결정하지 못할 수도 있습니다.

예:

두 개의 오버로드된 f가 있는 다음 클래스를 고려하세요. () 함수:

class A {
    void f(char c);
    void f(int i);

    void scan(const std::string& s) {
        std::for_each(s.begin(), s.end(), f); // Error!
    }
};
로그인 후 복사

f() 호출이 모호하기 때문에 컴파일러 오류가 발생합니다. 이 문제를 해결하려면 사용할 오버로드를 명시적으로 지정해야 합니다.

해결책 1: static_cast<>() 사용

이를 수행하는 한 가지 방법은 다음과 같습니다. 표시된 것처럼 함수 포인터를 적절한 서명으로 캐스팅하기 위해 static_cast<>()를 사용합니다. 아래:

// Uses the void f(char c); overload
std::for_each(s.begin(), s.end(), static_cast<void (*)(char)>(&amp;f));
// Uses the void f(int i); overload
std::for_each(s.begin(), s.end(), static_cast<void (*)(int)>(&amp;f));
로그인 후 복사

해결책 2: 포인터 선언

또는 함수 서명을 암시적으로 지정하는 포인터 선언을 활용할 수도 있습니다. 이 접근 방식을 사용하면 컴파일러는 호출할 올바른 오버로드를 자동으로 추론할 수 있습니다.

// The compiler will figure out which f to use according to
// the function pointer declaration.
void (*fpc)(char) = &amp;f;
std::for_each(s.begin(), s.end(), fpc); // Uses the void f(char c); overload
void (*fpi)(int) = &amp;f;
std::for_each(s.begin(), s.end(), fpi); // Uses the void f(int i); overload
로그인 후 복사

멤버 함수

f() 함수가 멤버 함수인 경우 mem_fun을 사용하거나 Dobb 박사의 기사에서 논의된 솔루션을 참조해야 합니다.

위 내용은 오버로드된 함수를 std::for_each()에 전달할 때 모호성을 해결하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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