可变参数模板和函数对象

Variadic templates and function objects

假设我们有两个函数对象,它们接受一个 int 和 return 一个布尔值:

struct EvenNumber {
  bool operator()(int const num) const {
   return num % 2 == 0;
  }
}

struct GreaterThenFive {
  bool operator()(int const num) const {
    return num > 5;
  }
}

现在假设我们有一个函数,它接受一个向量和一个过滤器的可变参数模板。该函数应该 return 一个新向量,该向量仅包含原始向量中满足过滤操作的那些元素:

template <typename... Filters>
std::vector<int> filter_out(std::vector<int> const& vec, Filters&&... filters) {
  std::vector<int> result;

  for (int const num : vec) {
    if (std::forward<filters>(filters)(num)...) {
      result.push_back(num);
    }
  }

  return result;
}

但这不适用于意想不到的标记...;预期的 )。我们这里需要折叠表达吗?如果我们想对原始向量的所有数字执行所有过滤操作,语法应该如何?

调用代码可以如下所示:

auto result = filter_out({1, 2, 3, 4, 5, 6, 7}, EvenNumber{}, GreaterThenFive{});

您不能只调用参数上的每个过滤器,您还需要对所有过滤器的结果进行析取。

if ((std::forward<Filters>(filters)(num) && ...)) {
                                      // ^^  ALL conditions must be satisfied

此外,forward 的参数必须是类型 Filters,而不是值 filters

这里是 demo