std::make_tuple doesn#39;t make references(std::make_tuple 不做引用)
问题描述
我一直在尝试将 std::tuple 与参考文献结合使用:
I've been experimenting with std::tuple in combination with references:
#include <iostream>
#include <tuple>
int main() {
int a,b;
std::tuple<int&,int&> test(a,b);
std::get<0>(test) = 1;
std::get<1>(test) = 2;
std::cout << a << ":" << b << std::endl;
// doesn't make ref, not expected
auto test2 = std::make_tuple(a,b);
std::get<0>(test2) = -1;
std::get<1>(test2) = -2;
std::cout << a << ":" << b << std::endl;
int &ar=a;
int &br=b;
// why does this not make a tuple of int& references? can we force it to notice?
auto test3 = std::make_tuple(ar,br);
std::get<0>(test3) = -1;
std::get<1>(test3) = -2;
std::cout << a << ":" << b << std::endl;
}
在这里的三个示例中,前两个按预期工作.然而第三个没有.我期望 auto 类型 (test3) 与 test 的类型相同(即 std::tuple<int&,int&>).
Of the three examples here the first two work as expected. The third one however does not. I was expecting the auto type (test3) to be the same as the type of test (i.e. std::tuple<int&,int&>).
似乎 std::make_tuple 不能自动生成引用的元组.为什么不?除了自己明确构建这种类型的东西之外,我还能做些什么来实现这一点?
It seems that std::make_tuple can't automatically make tuples of references. Why not? What can I do to make this the case, other than explicitly constructing something of that type myself?
(编译器是 g++ 4.4.5,使用 4.5 不会改变它)
(Compiler was g++ 4.4.5, using 4.5 doesn't change it)
推荐答案
试试forward_as_tuple:
auto test3 = std::forward_as_tuple(ar,br);
这篇关于std::make_tuple 不做引用的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
本文标题为:std::make_tuple 不做引用
基础教程推荐
- 如何部分禁用 cmake C/C++ 自定义编译器检查 2021-01-01
- 与 CAS 的原子交换(使用 gcc 同步内置函数) 2022-01-01
- 将不可复制的闭包对象传递给 std::function 参数 2021-01-01
- 为什么我们不能使用“虚拟继承"?在 COM 中? 2022-01-01
- 如何在 C++ 中正确使用命名空间? 2022-01-01
- C++:获取传递给函数的多维数组的行大小 2021-01-01
- 随机插入/删除的综合向量与链表基准 2022-01-01
- 如何更改 SysDateTimePick32 或 CDateTimeCtrl 的背景颜色? 2022-01-01
- c++ STL设置差异 2022-01-01
- 提升 ASIO 流缓冲 2021-01-01
