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 实现资源转移,减少拷贝开销

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

相关推荐
WBluuue8 小时前
数据结构与算法:康托展开、约瑟夫环、完美洗牌
c++·算法
木子墨5168 小时前
LeetCode 热题 100 精讲 | 并查集篇:最长连续序列 · 岛屿数量 · 省份数量 · 冗余连接 · 等式方程的可满足性
数据结构·c++·算法·leetcode
王老师青少年编程9 小时前
csp信奥赛C++高频考点专项训练之贪心算法 --【线性扫描贪心】:均分纸牌
c++·算法·编程·贪心·csp·信奥赛·均分纸牌
weixin_5134499610 小时前
PCA、SVD 、 ICP 、kd-tree算法的简单整理总结
c++·人工智能·学习·算法·机器人
烟锁池塘柳010 小时前
一文讲透 C++ / Java 中方法重载(Overload)与方法重写(Override)在调用时机等方面的区别
java·c++·面向对象
yolo_guo11 小时前
glog单行 30000 字节限制问题
c++
cccccc语言我来了11 小时前
C++轻量级消息队列服务器
java·服务器·c++
闻缺陷则喜何志丹11 小时前
【背包 组合】P7552 [COCI 2020/2021 #6] Anagramistica|普及+
c++·算法·背包·洛谷·组合
xiaoye-duck11 小时前
【C++:C++11】C++11新特性深度解析:从类新功能、Lambda表达式到包装器实战
开发语言·c++·c++11
一个行走的民12 小时前
C++ Lambda 表达式语法详解
c++