标准库是否有办法检查两个模板类型的基本模板类型是否相等?
Does the standard library have a way to check the equality of two templated types' base template type?
无法找到正确的术语来充分搜索它,但是标准库是否有一些东西可以测试相同的基本模板类型?
template <typename T>
struct foo {};
template <typename T>
struct bar {};
static_assert(std::is_same_base_type<foo<int>, foo<float>>::value == 1);
static_assert(std::is_same_base_type<foo<int>, bar<int>>::value == 0);
在标准库中?
没有,据我所知
但是写起来很简单。
template <typename, typename>
struct is_same_template : public std::false_type
{ };
template <template <typename> class C, typename T, typename U>
struct is_same_template<C<T>, C<U>> : public std::true_type
{ };
所以你可以这样写
static_assert( true == is_same_template<foo<int>, foo<float>>::value, "!" ) ;
static_assert( false == is_same_template<foo<int>, bar<int>>::value, "!" );
此解决方案的问题在于,专业化仅适用于仅接收一个模板类型参数的模板-模板库。
您可以改进它,因为基(模板-模板参数)接收可变参数列表
template <template <typename...> class C,
typename ... Ts, typename ... Us>
struct is_same_template<C<Ts...>, C<Us...>> : public std::true_type
{ };
但这无法通过示例来检查std::array
static_assert( true == is_same_template<std::array<int, 3u>,
std::array<float, 5u>>::value, "!" ) ;
对于std::array
,您必须添加另一个专业化
template <template <typename, std::size_t> class C,
typename T1, std::size_t S1, typename T2, std::size_t S2>
struct is_same_template<C<T1, S1>, C<T2, S2>> : public std::true_type
{ };
不幸的是,有无数种可能的模板-模板签名,因此您必须添加无数 is_same_template
专业化。
这就是(我想)没有标准库类型特征的原因。
无法找到正确的术语来充分搜索它,但是标准库是否有一些东西可以测试相同的基本模板类型?
template <typename T>
struct foo {};
template <typename T>
struct bar {};
static_assert(std::is_same_base_type<foo<int>, foo<float>>::value == 1);
static_assert(std::is_same_base_type<foo<int>, bar<int>>::value == 0);
在标准库中?
没有,据我所知
但是写起来很简单。
template <typename, typename>
struct is_same_template : public std::false_type
{ };
template <template <typename> class C, typename T, typename U>
struct is_same_template<C<T>, C<U>> : public std::true_type
{ };
所以你可以这样写
static_assert( true == is_same_template<foo<int>, foo<float>>::value, "!" ) ;
static_assert( false == is_same_template<foo<int>, bar<int>>::value, "!" );
此解决方案的问题在于,专业化仅适用于仅接收一个模板类型参数的模板-模板库。
您可以改进它,因为基(模板-模板参数)接收可变参数列表
template <template <typename...> class C,
typename ... Ts, typename ... Us>
struct is_same_template<C<Ts...>, C<Us...>> : public std::true_type
{ };
但这无法通过示例来检查std::array
static_assert( true == is_same_template<std::array<int, 3u>,
std::array<float, 5u>>::value, "!" ) ;
对于std::array
,您必须添加另一个专业化
template <template <typename, std::size_t> class C,
typename T1, std::size_t S1, typename T2, std::size_t S2>
struct is_same_template<C<T1, S1>, C<T2, S2>> : public std::true_type
{ };
不幸的是,有无数种可能的模板-模板签名,因此您必须添加无数 is_same_template
专业化。
这就是(我想)没有标准库类型特征的原因。