template<typename U,template<typename> class T>voID test(T<U>&& t){ ...}
我希望这可以接受左值和左值,但只适用于右值.崩溃规则“T&&& = T&”在这种情况下不适用?
当然,我也可以声明左值引用函数,但是使代码的可读性降低.
如果你问我为什么需要这个就是使用static_assert来检查T是否是一个特定的类.如果有一种更简单的方法,我会很乐意改变我的代码,但我想知道模板模板是否可以这种方式使用.
谢谢
解决方法 与可以推断为引用类型的typename T不同,模板< typename> T类只能被推断为类模板,因此T< U>总是推导出一种对象类型.您可以在T上编写模板化的函数,然后在static_assert中解压缩模板类型:
template<typename T> struct is_particular_class: std::false_type {};template<typename U> struct is_particular_class<ParticularClass<U>>: std::true_type {};template<typename T> voID test(T &&) { static_assert(is_particular_class<std::remove_reference<T>::type>::value,"!");}总结
以上是内存溢出为你收集整理的c – 模板模板功能和参数推导全部内容,希望文章能够帮你解决c – 模板模板功能和参数推导所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)