c – 如何使用可变模板参数enable_if一个类?

前端之家收集整理的这篇文章主要介绍了c – 如何使用可变模板参数enable_if一个类?前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
假设我有一个具有以下签名的类:
template <typename T,typename... Args>
class A;

但是,这个类的行为应该取决于一些其他参数,我们假设它是T :: value的值:

template <typename T,typename... Args,typename Enable>
class A;

template <typename T,typename = typename std::enable_if<T::value>::type>
class A
{
  // do something
};

template <typename T,typename = typename std::enable_if<!T::value>::type>
class A
{
  // do something else
};

int main() { return 0; }

但是,该程序提供以下错误

prog.cpp:6:11: error: parameter pack ‘Args’ must be at the end of the
template parameter list
class A;

我一直在努力寻找关于使用enable_if来选择具有可变模板的类的一个很好的信息源.我唯一能找到的问题是这个:

How to use std::enable_if with variadic template

但是,尽管这个名字,这个问题及其答案并没有多大帮助.如果有人可以提供或链接关于如何接近的指南,以及为什么不赞赏.

解决方法

首先,您正在尝试的是编写类模板的多个定义.这是不允许的,因为它违反了一个定义规则.如果要使用类进行条件启用,则需要专门化.此外,编译器错误消息已经告诉你,在参数列表的中间不能有一个可变参数包.

一种方法是:

namespace detail {

template<typename T,typename Enable,typename... Args>
class A_impl;

template<typename T,typename... Args>
class A_impl<T,typename std::enable_if<T::value>::type,Args...> {
    // code here
};

template<typename T,typename std::enable_if<!T::value>::type,Args...> {
    // code here
};
}

template<typename T,typename...Args>
class A : public detail::A_impl<T,void,Args...> {};

如果条件真的是一个bool,那么Jonathan’s way也是非常好的,但是如果你希望添加更多的专业化,这些专业化依赖于几个条件,这可能并不有用.

猜你在找的C&C++相关文章