结构化绑定,参考?是否可以删除它们

Ant*_*ier 4 c++ c++17 structured-bindings

假设我有这样一个元组。

std::tuple<int &, int> tuple{};
Run Code Online (Sandbox Code Playgroud)

我想做这样的事情:

auto [i1, i2] = tuple; // Here i1 is lvalue reference, i2 is int
Run Code Online (Sandbox Code Playgroud)

i1 是左值引用,因为元组上的第一个值是一个左值引用。不过,我没有写auto &[i1, i2]。那么,在这种情况下是否有可能“删除”引用?所以我得到了 i1 和 i2 作为“简单”int。谢谢 !

M.M*_*M.M 5

此结构化绑定等效于:

auto e = tuple;  
auto&& i1 = e.get<1>();
auto&& i2 = e.get<2>();
Run Code Online (Sandbox Code Playgroud)

既然tuple有类型std::tuple<int&, int>,那也是 的类型e

结构化绑定语法没有从tuple. 但是,您可以创建一个辅助函数来做到这一点,就像在这个问题中一样。这是一个工作示例:

#include <tuple>
#include <iostream>

template <typename... T>
using tuple_with_removed_refs = std::tuple<typename std::remove_reference<T>::type...>;

template <typename... T>
tuple_with_removed_refs<T...> remove_ref_from_tuple_members(std::tuple<T...> const& t) {
    return tuple_with_removed_refs<T...> { t };
}

int main()
{
    int x{5}, y{6};

    std::tuple<int& , int> t(x, y);

    auto [i1, i2] = remove_ref_from_tuple_members(t);

    std::cout << i1 << ' ' << i2 << '\n';
    i1 = 7; i2 = 8;
    std::cout << x << ' ' << y << '\n';
}
Run Code Online (Sandbox Code Playgroud)

输出:

5 6
5 6
Run Code Online (Sandbox Code Playgroud)