2023年8月15日
概述
移动构造函数是一个特殊的构造函数,用于从一个对象中移动(转移)资源到另一个对象,而不是进行复制操作。它通常与右值引用一起使用,以实现高效的资源转移,提高性能。
语法
class MyClass {
public:
MyClass(MyClass&& m) noexcept {
// 执行资源的转移操作
}
};
使用noexcept是为了防止在移动构造函数转移资源时,因为出现异常而导致资源还没转移完就中断了。
移动构造函数的参数是一个右值引用(&&
),用于接收要移动的对象。
在移动构造函数中,通常会执行资源的转移操作,例如将指针从一个对象转移到另一个对象,或者将动态分配的内存从一个对象转移到另一个对象。转移资源的操作可以通过简单的成员赋值或使用 std::move
函数来实现。
移动构造函数通常被编译器自动生成,如果没有显式定义移动构造函数,编译器会根据需要自动生成一个默认的移动构造函数。默认的移动构造函数会逐个成员变量地调用其移动构造函数,或者使用复制构造函数进行复制,具体取决于成员变量的类型。
移动构造函数经常与移动语义一起使用,以避免不必要的复制操作和资源的重复分配。通过使用移动构造函数,可以将对象的资源转移到另一个对象,而不是进行昂贵的复制操作,从而提高性能。
举例说明
#include <iostream>
#include <string>
class MyString {
public:
MyString(const std::string& str) : data(new std::string(str)) {
std::cout << "Constructor: " << *data << std::endl;
}
MyString(MyString&& other) noexcept : data(other.data) {
other.data = nullptr;
std::cout << "Move constructor: " << *data << std::endl;
}
~MyString() {
delete data;
}
private:
std::string* data;
};
int main() {
std::string str = "Hello";
MyString obj1(str); // 调用构造函数
MyString obj2(std::move(obj1)); // 调用移动构造函数
return 0;
}