c++ - 遍历参数包

标签 c++ c++17 variadic-templates

我有一个参数包 args... 任意类型的 vector ,对应的有一个索引 vector 说 v = {3,0,5...} 的大小和顺序与 args... 的成员数相同。我希望 get_tuplev 给定的索引处返回 args... 元素的元组。

这是我目前所拥有的,但我一直在尝试迭代参数包的成员。

template<typename... Args>
auto get_tuple(const std::vector<size_t>& vector, const Args &... args) {
    return std::make_tuple(args[v[0]]...);
}

例如:

std::vector<std::string> v1 = {"a", "b"};
std::vector<int> v2 = {1,2};
std::vector<size_t> v = {0,1};
auto result = get_tuple(v, v1, v2); // ("a",2) expected

最佳答案

在 C++17 中,您需要额外的间接级别来获取一组索引以获取这些索引处的一组元素:

template<typename... Args, std::size_t... Is>
auto get_tuple_impl(const std::vector<std::size_t>& indices,
                    std::index_sequence<Is...>,
                    const Args&... args) {
    return std::make_tuple(args[indices[Is]]...);
}

template<typename... Args>
auto get_tuple(const std::vector<std::size_t>& indices, const Args&... args) {
    return get_tuple_impl(indices, std::index_sequence_for<Args...>(), args...);
}

在 C++20 中,我们可以为您提供一个带有就地调用模板参数的 lambda 函数:

template<typename... Args>
auto get_tuple(const std::vector<std::size_t>& indices, const Args&... args) {
    return [&]<std::size_t... Is>(std::index_sequence<Is...>) {
        return std::make_tuple(args[indices[Is]]...);
    }(std::index_sequence_for<Args...>());
}

您可能还想添加一个断言 assert(indices.size() == sizeof...(Args));或使用 std::array<std::size_t, N>改为输入。

关于c++ - 遍历参数包,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/71347375/

相关文章:

c++ - Constexpr 类采用 const 引用未编译

c++ - 在此上下文中的完美转发和 std::move 行为

c++ - 是否有任何关于 Boost 库 C++ 和 C++ 中的面向对象设计的好书?

c++ - 为什么在函数参数类型中使用模板参数包作为其模板参数列表无法显式指定

c++ - 如何在成员初始化器列表中初始化数组

c++17 有效地将参数包参数与 std::array 元素相乘

c++ - 已知最有效的尾递归质数验证函数是什么?

c++ - Variadic 可转换检查类中的参数

c++ - 如何在添加后 30 秒内从链表中删除项目?

c++ - C++ 中的 2 的补码转换器