>백엔드 개발 >C++ >C에서 활성화_if를 사용하여 조건부 멤버 함수 오버로드를 구현하는 방법은 무엇입니까?

C에서 활성화_if를 사용하여 조건부 멤버 함수 오버로드를 구현하는 방법은 무엇입니까?

Patricia Arquette
Patricia Arquette원래의
2024-10-28 14:18:30757검색

How to Implement Conditional Member Function Overloads Using enable_if in C  ?

다른 활성화_if 조건을 사용하여 멤버 함수 선택

C에서 활성화_if는 여부에 따라 특정 코드를 조건부로 활성화하거나 비활성화하는 데 사용되는 도구입니다. 템플릿 인수는 특정 기준을 충족합니다. 이는 템플릿 매개변수를 기반으로 클래스나 함수의 동작을 사용자 정의하려는 경우 유용할 수 있습니다.

주어진 예에서 목표는 템플릿이 적용되는지 여부에 따라 다르게 동작하는 MyFunction 멤버 함수를 만드는 것입니다. 매개변수 T는 정수이거나 아닙니다. 의도된 구현은 MyFunction의 두 오버로드(T = int에 대해 하나, T != int에 대해 하나)를 사용하는 것입니다.

이를 달성하기 위한 한 가지 접근 방식은 아래 코드에 표시된 대로 활성화_if를 사용하는 것입니다.

<code class="cpp">template<typename T>
struct Point {
  void MyFunction(
    typename std::enable_if<std::is_same<T, int>::value, T >::type* = 0) {
    std::cout << "T is int." << std::endl;
  }

  void MyFunction(
    typename std::enable_if<!std::is_same<T, int>::value, float >::type* = 0) {
    std::cout << "T is not int." << std::endl;
  }
};</code>

그러나 이 코드는 활성화_if의 잘못된 사용으로 인해 컴파일 오류가 발생합니다. C에서는 오버로드 해결 중에 템플릿 인수 대체가 발생합니다. 이 경우 멤버 함수 인스턴스화 시 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>

이 접근 방식을 사용하면 T 값에 따라 올바른 버전의 MyFunction이 선택됩니다.

위 내용은 C에서 활성화_if를 사용하여 조건부 멤버 함수 오버로드를 구현하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.