c – 实现拉链功能
发布时间:2020-12-16 07:00:53 所属栏目:百科 来源:网络整理
导读:这是我的代码(其中我不确定它是否正确): templatetypename... list struct typeList;templatetypename,typename struct zipper;templatetypename...L,typename...R struct zippertypeListL...,typeListR...{ typedef std::tuplestd::pairL,R... tuplez; sta
这是我的代码(其中我不确定它是否正确):
template<typename... list> struct typeList; template<typename,typename> struct zipper; template<typename...L,typename...R> struct zipper<typeList<L...>,typeList<R...>> { typedef std::tuple<std::pair<L,R>...> tuplez; static_assert(sizeof...(L)==sizeof...(R),"Mismatch number of Args..."); static void print() { std::cout<<"The types are: "<<std::endl; for(int i=0; i<std::tuple_size<tuplez>::value ; ++i) std::cout<< "first : "<< typeid(typename std::tuple_element<i,tuplez>::type::first_type).name()<< "second : "<<typeid(typename std::tuple_element<i,tuplez>::type::second_type).name() <<std::endl; } }; 首先,我很惊讶我的拉链实现如此之小(一定是错误的我真的很确定).如果我的实施是错误的,请告诉我为什么这是错误的而不是给我解决方案. 此外,如果我运行此代码(zipper< typeList< int,double>,typeList< char,int>> :: print();),我会遇到大量错误: 以下是完整代码的完整错误列表(来自ideone): P.S:请编辑合适的问题标题,我不能再提出更合理的问题. 编辑:感谢@KerrekSB和@Ugo的建议,以下是解决方案: template<typename... list> struct typeList; template<int n,typename T> struct printer { static void print (){ std::cout<< "first : "<< typeid(typename std::tuple_element<n,T>::type::first_type).name()<< "second : "<<typeid(typename std::tuple_element<n,T>::type::second_type).name() <<std::endl; printer<n-1,T>::print(); } }; template<typename,R>...> tuplez; static void print(){ printer<std::tuple_size<tuplez>::value-1,tuplez>::print(); } }; template<typename T> struct printer<0,T> { static void print (){ std::cout<< "first : "<< typeid(typename std::tuple_element<0,T>::type::first_type).name()<< "second : "<<typeid(typename std::tuple_element<0,T>::type::second_type).name() <<std::endl; } }; 解决方法
模板非类型参数必须是常量表达式. 我这里是一个运行时变量,你不能用它作为模板参数.
(编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |