右值引用和移动语义是C++11根本性升级,通过T&&绑定临时对象并显式定义移动构造/赋值函数,实现资源窃取而非拷贝;需配合std::move使用,且仅对管理堆内存等重型资源的类型有显著性能提升。

右值引用和移动语义是 C++11 引入的两大核心机制,本质是让编译器能“安全地复用资源”,避免无谓的深拷贝——不是语法糖,而是改变对象生命周期管理方式的根本性升级。
右值引用:&& 不是“两个引用”,而是绑定临时对象的新类型
右值引用(T&&)只能绑定到即将销毁的表达式(如字面量、函数返回的临时对象、std::move() 转换后的对象),它本身不延长对象寿命,但提供了“接管资源”的入口。
关键点:
- 不能绑定到具名变量(左值),除非显式用 std::move() “标记为可移动”
- 函数重载中,右值引用版本优先匹配临时对象,实现“按值分类调度”
- 完美转发依赖右值引用 + 模板参数推导(T&& 在模板中是万能引用,非严格右值引用)
移动构造/赋值:真正发生“资源窃取”的地方
移动操作不是自动发生的,必须由你显式定义移动构造函数和移动赋值运算符。它们的核心逻辑是:把源对象的指针/句柄“拿走”,再把源对象置为有效但未定义状态(如指针设为 nullptr)。
立即学习“C++免费学习笔记(深入)”;
典型写法示例(简化):
class String {
char* data_;
size_t size_;
public:
// 移动构造:接管资源,原对象“掏空”
String(String&& other) noexcept
: data_(other.data_), size_(other.size_) {
other.data_ = nullptr; // 关键:防止析构时重复释放
other.size_ = 0;
}
<pre class='brush:php;toolbar:false;'>// 移动赋值:先清理自己,再接管
String& operator=(String&& other) noexcept {
if (this != &other) {
delete[] data_;
data_ = other.data_;
size_ = other.size_;
other.data_ = nullptr;
other.size_ = 0;
}
return *this;
}登录后复制
};
版权声明:除非特别标注,否则均为本站原创文章,转载时请以链接形式注明文章出处。
还木有评论哦,快来抢沙发吧~