我试图使用紧凑的折叠表达而没有成功。
例如,这是一个工作 C ++ 17代码
template <bool... B>
struct Fold_And : std::integral_constant<bool, (B && ...)>
{
};
template <bool... B>
constexpr auto Fold_And_v = Fold_And<B...>::value;
template <typename V, typename... Vs>
std::enable_if_t<
Fold_And_v<std::is_floating_point_v<V>,
std::is_floating_point_v<Vs>...> >
foo(const V& v, const Vs&...)
{
}
我想将其翻译成更紧凑的形式(不使用中间Fold_And
)
template <typename V, typename... Vs>
std::enable_if_t<std::is_floating_point_v<V> && ... &&
std::is_floating_point_v<Vs> >
foo_compact(const V& v, const Vs&...)
{
}
然而,这显然是非法的C ++,因为g ++和clang ++编译器都无法编译它。
我的问题:
foo_compact()
中的语法问题? (什么是正确的?)或者
foo()
结构的Fold_And
代码)更好吗?答案 0 :(得分:14)
你几乎得到了它!折叠表达式有被括号括起来:
template <typename V, typename... Vs>
std::enable_if_t<(std::is_floating_point_v<V> && ... &&
std::is_floating_point_v<Vs>)>
foo_compact(const V& v, const Vs&...)
{
}
请注意<
之后和最后>
之前的括号。
答案 1 :(得分:6)
折叠表达式需要括号,所以:
(std::is_floating_point_v<V> && ... && std::is_floating_point_v<Vs>)