다른 활성화_if 조건을 사용하여 멤버 함수 선택
enable_if 메타함수는 템플릿 함수 매개변수를 지정하고 이를 기반으로 적절한 멤버 함수를 선택하는 데 사용됩니다. . 다음 코드를 고려하십시오.
<code class="cpp">template<typename T> struct Point { // Check if T is int and call MyFunction for int void MyFunction(typename std::enable_if<std::is_same<T, int>::value, T &>::type* = 0) { std::cout << "T is int." << std::endl; } // Check if T is not int and call MyFunction for non-int void MyFunction(typename std::enable_if<!std::is_same<T, int>::value, float &>::type* = 0) { std::cout << "T is not int." << std::endl; } };</code>
그러나 이 코드는 "'struct std::enable_if'에 'type'이라는 유형이 없음"을 나타내는 컴파일러 오류를 일으킬 수 있습니다.
활성화_if
enable_if를 이해하면 오버로드 해결 중에 실행 가능한 함수 오버로드만 고려됩니다. 템플릿 인수 대체가 실패하면 해당 오버로드가 후보 세트에서 제거됩니다.
위의 예에서 템플릿 인수 T는 멤버 함수를 인스턴스화할 때 이미 알려져 있습니다. 원하는 동작을 구현하기 위해 기본적으로 T로 설정된 더미 템플릿 인수를 만들고 이를 사용하여 SFINAE를 수행할 수 있습니다.
<code class="cpp">template<typename T> struct Point { template<typename U = T> typename std::enable_if<std::is_same<U, int>::value>::type MyFunction() { std::cout << "T is int." << std::endl; } template<typename U = T> typename std::enable_if<std::is_same<U, float>::value>::type MyFunction() { std::cout << "T is not int." << std::endl; } };</code>
위 내용은 템플릿 인수를 기반으로 멤버 함수를 선택하기 위해 활성화_if를 사용하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!