我已经测试了C++ 11中的移动语义。我用移动构造函数写了一个类。为什么C++ 11移动运算符(=)的行为不同
class DefaultConstructor
{
public:
DefaultConstructor(std::vector<int> test) :
m_vec(std::forward<std::vector<int>>(test))
{
};
DefaultConstructor(DefaultConstructor &&def) :
m_vec(std::forward<std::vector<int>>(def.m_vec))
{
}
DefaultConstructor& operator=(DefaultConstructor&& def) {
m_vec = std::move(def.m_vec);
return *this;
}
DefaultConstructor& operator=(const DefaultConstructor&) = delete;
DefaultConstructor(DefaultConstructor &) = delete;
std::vector<int> m_vec;
};
我写了一个使用移动语义的主函数。我明白移动语义中发生了什么,它是一个很好的工具。但是有一些行为对我来说是无法解释的。当我呼叫DefaultConstructor testConstructor2 = std::move(testConstructor);
的主要功能时,应该调用DefaultConstructor& operator=(DefaultConstructor&& def)
。但Visual Studio 2015调用移动构造函数。
int main()
{
std::vector<int> test = { 1, 2, 3, 4, 5 };
DefaultConstructor testConstructor(std::move(test));
DefaultConstructor testConstructor2 = std::move(testConstructor);
DefaultConstructor &testConstructor3 = DefaultConstructor({ 6, 7, 8, 9 });
DefaultConstructor testConstructor4 = std::move(testConstructor3);
swapMove(testConstructor, testConstructor2);
}
好吧,我想也许=移动运算符不再是必要的。但我尝试了一个SwapMove函数。这个函数调用= move操作符。
template<typename T>
void swapMove(T &a, T &b)
{
T tmp(std::move(a));
a = std::move(b);
b = std::move(tmp);
}
有人可以解释这两个电话之间的区别究竟是什么?不应该是电话a = std::move(b);
和DefaultConstructor testConstructor2 = std::move(testConstructor);
有相同的行为?
'DefaultConstructor testConstructor2 = std :: move(testConstructor);'是初始化,不是赋值。 –
事先分别声明'testConstructor2',例如'DefaultConstructor testConstructor2({});' –
Jonatha Potter看起来像这就是答案。谢谢。 – PeterNL