给定一个模板化类,有没有办法获得“基本”/非模板化类型?

时间:2021-04-23 15:22:48

标签: c++

很简单,但也许不可能:给定一些 T<some_type>,有没有办法得到 T?这里有一个更好的代码示例:

template<class T>
struct parametrized_class{
   
};

template<class T>
using make_floaty = T<float>; // this doesn't compile since T is not the "base" type

int main() {
   using int_class = parametrized_class<int>;
   using float_class = make_floaty<int_class>;
}

我不认为是,但我想确定一下。

2 个答案:

答案 0 :(得分:5)

你绝对可以,虽然模板不是一等公民让它有点棘手:

template <class T>
struct make_floaty;

template <template <class> class Template, class T>
struct make_floaty<Template<T>> {
    using type = Template<float>;
};

template <class T>
using make_floaty_t = typename make_floaty<T>::type;

See it live on Wandbox

答案 1 :(得分:0)

通过使用模板模板参数,您可以编写一个特征,给出一个模板和另一种类型的实例化,它“返回”具有该另一种类型的实例化:

template <typename OLDINSTANTIATION,typename NEWPARAMETER>
struct replace_template_parameter;

template <template<typename...> class T,typename OLDPARAM,typename NEWPARAM>
struct replace_template_parameter< T<OLDPARAM>,NEWPARAM> {
    using type = T<NEWPARAM>;
};

make_floaty 然后可以写成:

template <class T>
using make_floaty = typename replace_template_parameter< T,float>::type;

Complete Example

#include <iostream>
#include <type_traits>

template<class T> struct parametrized_class{};

template <typename OLDINSTANTIATION,typename NEWPARAMETER> struct replace_template_parameter;

template <template<typename...> class T,typename OLDPARAM,typename NEWPARAM>
struct replace_template_parameter< T<OLDPARAM>,NEWPARAM> {
    using type = T<NEWPARAM>;
};

template <class T> using make_floaty = typename replace_template_parameter< T,float>::type;

int main() {
   using int_class = parametrized_class<int>;
   using float_class = make_floaty<int_class>;
   std::cout << std::is_same< float_class, parametrized_class<float>>::value;
}
相关问题