微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

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也是非常好的,但是如果你希望添加更多的专业化,这些专业化依赖于几个条件,这可能并不有用.

原文地址:https://www.jb51.cc/c/114915.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐