浅拷贝优势:不需要考虑目标对象中的资源分配, 也不用在两个对象空间之间复制庞大资源数据。又快又省内存。对于目标对象的指针成员变量就是复制,而是共享。
#include <iostream>
using namespace std;
class Foo
{
public:
int *p;
Foo(int x)
{
p = new int(x);
}
Foo(const Foo& r)
{
this->p = r.p;
}
//移动拷贝构造函数
Foo(Foo&& r)
{
cout << "移动构造" << endl;
this->p = r.p;
r.p = nullptr;//不需要考虑临时资源释放
}
~Foo()
{
delete p;
}
void show_p()
{
cout << p << " " << *p << endl;
}
};
Foo func()
{
Foo f(50);
return f;
}
int main()
{
/*浅拷贝
Foo Object(50);
Foo CopyObject(Object);
return 0;
end */
Foo CopyObject(func());
//在 C++ 中,std::move 是一个类型转换工具,它的作用是将一个对象转换为右值引用,从而启用移动语义而不是拷贝语义。
Foo CopyObjectTwo(std::move(CopyObject));
int a = 1;
}
1、转移语义(Move Semantics)
转移语义允许我们在对象拷贝时,不是简单地复制数据,而是将资源的所有权从一个对象转移到另一个对象。这样做的一个重要好处是,我们可以避免不必要的资源拷贝,从而提高效率。
例如,考虑一个包含动态分配内存的类。如果我们使用传统的拷贝构造函数进行拷贝,通常会导致昂贵的深拷贝操作,即为每个对象分配新的内存并复制内容。但是,如果我们使用转移语义,我们可以通过“转移”资源(而不是拷贝)来避免这笔开销。
2. 转移语义的实现
转移语义的核心思想是通过右值引用和移动构造函数,将资源的所有权从一个对象转移到另一个对象,而不是复制资源。
右值引用拷贝构造函数(通常称为 移动构造函数)