为什么无法在可变参数模板中将尾随模板参数指定为默认值?
Why is it not possible to specify trailing template parameters as default in a variadic template?
是否有真正的技术原因不允许
template< class... Ts, class = std::enable_if</*...*/> >
struct S{};
我不明白为什么上面的代码是不允许的,下面的代码是
template< class T1, class T2, class = std::enable_if</*...*/> >
struct S{};
C++ 标准规定可变参数包必须是最后一个(作为模板类的包;对于函数,存在不同的规则(。
因此,在第二种情况下,您没有可变参数包。 所以这是允许的。
如果你想知道为什么C++标准规定可变参数包必须是最后一个,主要是因为没有人给出令人信服的论据,为什么应该改变它。
通过最后使用可变包,匹配规则将更简单(可变包匹配所有内容(和清晰。 一旦你添加了"哦,你可以添加默认值"或其他什么,措辞就会变得更加棘手,最好的选择会变得更加混乱。
template<class... Ts, class Tail>
struct foo {};
foo<int, double>
应该double
传递给Tail
吗? 还是应该失败? 谈论这个,你可以洒出墨水的海洋。
那么模板专业化呢? 我不寒而栗。
将其用于enable_if
东西不会是一个强有力的销售,因为概念就在这里,可以解决大多数(如果不是全部(enable_if
条款问题。
相关文章:
- 当给定默认值时,为什么此模板参数推导失败
- 如何在C++中提供模板化函数作为另一个函数的参数,默认值?
- 在 c++ 中,如果我创建一个接受一个具有默认值的参数的构造函数 - 它会用作默认(空)构造函数吗?
- 为什么无法在可变参数模板中将尾随模板参数指定为默认值?
- 可变参数模板和具有继承的默认值
- 具有默认值的单个参数构造函数是否与默认构造函数相同?
- 在子类函数覆盖中省略具有默认值的参数
- 函数作为具有默认值的参数
- 具有另一个具有默认值的模板参数的模板推导
- const变量是否可以在具有默认值的参数中赋值(作为可选参数)
- 可以通过常量引用返回默认参数的值吗?
- 对 const 引用参数使用默认值会导致崩溃
- C ,构造器中允许的参考参数默认值
- 是否可以设计一个包含模板参数默认值的类
- 构造函数中参数C++默认值
- 如何设置依赖于其他参数的参数默认值
- QInput对话框参数默认值
- 在函数定义中指定参数默认值会导致错误 C2143:语法错误:'='之前缺少')'
- 内置类型的模板参数默认值
- 是否可以使用构造函数或对象作为其他类方法的参数默认值?