오버로드된 함수에 대한 포인터 지정
C 영역에서는 이름은 같지만 오버로드된 함수를 만나는 것은 드문 일이 아닙니다. 입력 매개변수가 다릅니다. 이는 std::for_each()와 같은 일반 알고리즘에 이러한 함수를 인수로 전달하려고 시도할 때 문제가 됩니다.
클래스 내의 중첩된 오버로드 함수
다음을 고려하세요. 클래스 내에서 오버로드가 발생하는 예:
class A { public: void f(char c); void f(int i); void scan(const std::string& s) { std::for_each(s.begin(), s.end(), f); } };
여기서는 다음과 같이 scan() 메서드를 호출합니다. 문자열은 컴파일러가 어떤 f 구현을 사용할지 불확실하게 만듭니다. 기본적으로 f()는 문자를 인수로 사용합니다. 그러나 사용자는 정수를 허용하는 오버로드를 사용하려고 할 수도 있습니다.
명시적 포인터 할당
이 모호성을 해결하려면 원하는 오버로드를 명시적으로 지정할 수 있습니다. 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));
함수 포인터를 적절한 위치에 캐스팅하여 유형을 사용하면 어떤 오버로드를 호출해야 하는지 컴파일러에 명시적으로 나타낼 수 있습니다.
함수 포인터를 사용하는 대체 방법
또 다른 접근 방식은 함수 포인터를 명시적으로 선언하는 것입니다.
// 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
특정 시그니처가 있는 함수 포인터를 생성함으로써 컴파일러는 자동으로 올바른 오버로드를 결정할 수 있습니다. use.
멤버 함수 처리
오버로드된 함수가 멤버 함수인 경우에는 다른 접근 방식이 필요합니다. mem_fun 템플릿 사용을 고려하거나 제공된 답변에 링크된 Dr. Dobb의 기사와 같은 추가 리소스를 참조하세요.
위 내용은 C에서 오버로드된 함수에 대한 포인터를 어떻게 지정할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!