很简单,但也许不可能:给定一些 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>;
}
我不认为是,但我想确定一下。
答案 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;
答案 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;
#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;
}