C++ 中的右值引用与移动语义

C++ 中的右值引用与移动语义

C++11 引入了右值引用(rvalue reference)和移动语义(move semantics),大幅优化了对象的拷贝效率。本文将详细讲解其原理与示例。


一、左值与右值

  • 左值:有名称、可取地址的变量
  • 右值:没有名称的临时对象或返回值
cpp 复制代码
int x = 5; // x 是左值
int y = x; // x 被拷贝
int z = 10 + 20; // 10+20 是右值

二、右值引用

右值引用使用 && 声明,可以绑定到右值:

cpp 复制代码
void print(int &&x) {
    std::cout << x << "\n";
}

int main() {
    print(5); // OK
    // int a = 10; print(a); // 错误,a 是左值
}

三、移动语义

移动语义通过 std::move 将资源从一个对象转移到另一个对象,避免不必要的拷贝:

cpp 复制代码
#include <iostream>
#include <vector>

int main() {
    std::vector<int> v1 = {1, 2, 3, 4};
    std::vector<int> v2 = std::move(v1); // 移动资源

    std::cout << "v1 size: " << v1.size() << "\n"; // 0
    std::cout << "v2 size: " << v2.size() << "\n"; // 4
}

四、移动构造与移动赋值

自定义类也可以实现移动构造和移动赋值:

cpp 复制代码
class MyClass {
    int* data;
public:
    MyClass(int n) : data(new int[n]) {}
    ~MyClass() { delete[] data; }

    // 移动构造
    MyClass(MyClass&& other) noexcept : data(other.data) {
        other.data = nullptr;
    }

    // 移动赋值
    MyClass& operator=(MyClass&& other) noexcept {
        if (this != &other) {
            delete[] data;
            data = other.data;
            other.data = nullptr;
        }
        return *this;
    }
};

总结

  • 右值引用允许函数接收临时对象

  • std::move 实现资源转移,减少拷贝开销

  • 移动构造和移动赋值可以优化类的性能

相关推荐
肆忆_10 小时前
# 用 5 个问题学懂 C++ 虚函数(入门级)
c++
不想写代码的星星14 小时前
虚函数表:C++ 多态背后的那个男人
c++
端平入洛2 天前
delete又未完全delete
c++
端平入洛3 天前
auto有时不auto
c++
哇哈哈20214 天前
信号量和信号
linux·c++
多恩Stone4 天前
【C++入门扫盲1】C++ 与 Python:类型、编译器/解释器与 CPU 的关系
开发语言·c++·人工智能·python·算法·3d·aigc
蜡笔小马4 天前
21.Boost.Geometry disjoint、distance、envelope、equals、expand和for_each算法接口详解
c++·算法·boost
超级大福宝4 天前
N皇后问题:经典回溯算法的一些分析
数据结构·c++·算法·leetcode
weiabc4 天前
printf(“%lf“, ys) 和 cout << ys 输出的浮点数格式存在细微差异
数据结构·c++·算法
问好眼4 天前
《算法竞赛进阶指南》0x01 位运算-3.64位整数乘法
c++·算法·位运算·信息学奥赛