我试图按照下面的代码使用std::tie()交换两个变量(我知道std::swap,我只是出于好奇而尝试):
#include <iostream>
#include <tuple>
using std::cin; using std::tie;
using std::cout; using std::endl;
using std::make_pair;
int main() {
int a = 2, b = 10;
cout << "Before Swapping using {}" << endl;
cout << "a: " << a << " b: " << b < <endl;
tie(a, b) = {b, a};
cout << "After Swapping using {}" << endl;
cout << "a: " << a << " b: " << b << endl;
a = 2, b = 10;
cout << "Before Swapping using make_pair()" << endl;
cout << "a: " << a << " b: " << b << endl;
tie(a, b) = make_pair(b, a);
cout << "After Swapping using make_pair()" << endl;
cout << "a: " << a << " b: " << b << endl;
return 0;
}我是用g++ test.cpp -std=c++11 -o test编译的。
但是输出是这样的:
Before Swapping using {}
a: 2 b: 10
After Swapping using {}
a: 10 b: 10
Before Swapping using make_pair()
a: 2 b: 10
After Swapping using make_pair()
a: 10 b: 2所以,我的问题是,既然我们可以编写{a, b}而不是每次都编写std::make_pair(a, b) (C++11之后的版本),为什么这两个版本给出了不同的输出?
我的猜测是下面这行
std::tie(a, b) = {b, a};并不是成对的,出于某种原因,只是改变了a的值。但我不确定。
发布于 2017-01-27 05:29:52
tie(a, b) = {b, a};
将使用std::tuple<int&, int&> operator = (std::tuple<int&, int&>&&)。而不是您所期望的std::tuple<int&, int&> operator = (std::tuple<int, int>&&)。
std::tie(a, b)是一个std::tuple<int&, int&>。
std::tuple有几个operator =,但对于(非类型化的) {a, b},唯一可行的是复制/移动赋值。
发布于 2017-01-27 05:29:37
{b, a}制作std::tuple<int&, int&>,而std::make_pair制作std::pair<int, int>。
考虑一下使用std::pair<int&, int&>会发生什么。它本质上是将一个变量赋给另一个变量,然后尝试将另一个变量赋给第一个变量。它等同于做a = b; b = a;或b = a; a = b;。
发布于 2017-01-27 05:46:54
只需使用make_tuple即可
std::tie(a, b) = std::make_tuple(b, a);这和a=b或b=a是一样的;
https://stackoverflow.com/questions/41883235
复制相似问题