Variadic函数用于检查STL容器的等长

时间:2016-04-06 15:18:31

标签: c++ c++11 variadic-templates

我正在编写我的第一个可变参数函数模板。我收到错误error: parameter packs not expanded with ‘...’:。可能我在这里无法理解一些简单的概念。我希望将iterators中的所有内容存储在vector中。这样做的正确方法是什么?

template<typename... Iterator>
bool IsEqualLength(Iterator&... its)
{
    std::vector<Iterator> vec_its {its...};
    int head = vec_its.front().size();

    bool is_diff_size = std::any_of(vec_its.begin(), vec_its.end(), 
        [&head](Iterator& cur){return cur.size() != head;});

    if(is_diff_size)
    {
        return false;
    } else {
        return true;
    }
}

无法编译(在Ubuntu上的gcc 4.8.4下):

../proc.h: In function ‘bool IsEqualLength(Iterator& ...)’:
../proc.h:32:24: error: parameter packs not expanded with ‘...’:
  std::vector<Iterator> vec_its {its...};
                        ^
../proc.h:32:24: note:         ‘Iterator’
../proc.h:35:87: error: parameter packs not expanded with ‘...’:

1 个答案:

答案 0 :(得分:4)

您在此声明中使用了两个不同的包:

std::vector<Iterator> vec_its {its...};

its已展开,但Iterator不是单一类型......它也是一个包,而您无法扩展它。因此错误(具体指出Iterator)。

如果你想要的只是容器的大小,你可以在所有传入的容器(容器,而不是迭代器!)上调用size()并将它放在一个数组中(不需要动态分配) :

template <typename... Container>
bool isEqualLength(Container&&... cs) {
    size_t sizes[] = {cs.size()...};

    return std::all_of(std::begin(sizes), std::end(sizes),
        [&sizes](size_t cur){return cur == sizes[0]; });
}