오버로드된 함수를 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)>(&f)); // Uses the void f(int i); overload std::for_each(s.begin(), s.end(), static_cast<void (*)(int)>(&f));
해결책 2: 포인터 선언
또는 함수 서명을 암시적으로 지정하는 포인터 선언을 활용할 수도 있습니다. 이 접근 방식을 사용하면 컴파일러는 호출할 올바른 오버로드를 자동으로 추론할 수 있습니다.
// The compiler will figure out which f to use according to // the function pointer declaration. void (*fpc)(char) = &f; std::for_each(s.begin(), s.end(), fpc); // Uses the void f(char c); overload void (*fpi)(int) = &f; std::for_each(s.begin(), s.end(), fpi); // Uses the void f(int i); overload
멤버 함수
f() 함수가 멤버 함수인 경우 mem_fun을 사용하거나 Dobb 박사의 기사에서 논의된 솔루션을 참조해야 합니다.
위 내용은 오버로드된 함수를 std::for_each()에 전달할 때 모호성을 해결하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!