제네릭 유형은 광범위한 데이터 유형에서 작동할 수 있는 클래스나 함수를 만드는 기능을 제공합니다. 그러나 경우에 따라 특정 유형만 허용하도록 일반 유형을 제한할 수도 있습니다. 여기서 제네릭 유형을 제한하는 개념이 적용됩니다.
Java에서는 확장 키워드를 사용하여 제네릭 클래스가 특정 클래스를 확장하는 유형만 허용하도록 제한할 수 있습니다. C에는 이 키워드와 직접적으로 동등한 것이 없습니다. 그러나 유사한 결과를 얻기 위해 사용할 수 있는 여러 접근 방식이 있습니다.
C 11에서는
#include <type_traits> template<typename T> class ObservableList { static_assert(std::is_base_of<list, T>::value, "T must inherit from list"); // code here... };
이 접근 방식은 ObservableList에서 T 유형의 사용을 허용하기 전에 목록에서 상속하는지 확인합니다. .
다른 접근 방식은 Duck Typing에 의존하는 것입니다. 기본 클래스에서 상속할 필요 없이 특정 메서드나 함수를 제공합니다. 이 접근 방식은 제한 사항이 적지만 유형이 예상 인터페이스를 준수하지 않는 경우 잠재적인 오류가 발생할 수 있습니다.
또 다른 옵션은 사용자 정의 특성을 정의하여 유형을 제한하는 것입니다. 특성은 다양한 유형 속성을 테스트하기 위한 함수 템플릿 세트를 제공하는 클래스 또는 구조입니다. 사용자 정의 특성을 정의하면 일반 유형과 함께 사용할 수 있는 유형에 대한 요구 사항을 지정할 수 있습니다.
#include <type_traits> template<typename T> struct HasConstIterator : std::false_type {}; template<typename T> struct HasConstIterator<T, Void<typename T::const_iterator>> : std::true_type {}; struct HasBeginEnd { template<typename T> static std::true_type Test(int); template<typename...> static std::false_type Test(...); }; template<typename T> class ObservableList { static_assert(HasConstIterator<T>::value, "Must have a const_iterator typedef"); static_assert(HasBeginEnd<T>::value, "Must have begin and end member functions"); // code here... };
이 예에서는 메타 프로그래밍 기술을 사용하여 구현된 사용자 정의 특성을 사용하여 특정 유형을 충족하도록 유형 T를 제한하는 방법을 보여줍니다. 인터페이스 요구 사항.
위 내용은 C에서 일반 유형을 어떻게 제한할 수 있나요?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!