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

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

相关推荐
小欣加油9 小时前
leetcode1926 迷宫中离入口最近的出口
数据结构·c++·算法·leetcode·职场和发展
星恒随风10 小时前
C++ 类和对象入门(五):初始化列表、explicit 和 static 成员详解
开发语言·c++·笔记·学习·状态模式
浪客灿心10 小时前
项目篇:模块设计与实现
数据库·c++
牛油果子哥q10 小时前
【C++ STL vector】C++ STL vector 终极精讲:动态数组底层原理、两倍扩容机制、迭代器失效、增删查改、性能剖析与工程避坑指南
开发语言·c++
为何创造硅基生物12 小时前
独占指针的创建std::make_unique 本身自带堆出现
c++
kyle~12 小时前
ROS 2 与 Isaac Sim 联合仿真(一)体系架构、环境选型与基础通信闭环
c++·机器人·nvidia·仿真·ros2
努力努力再努力wz13 小时前
【内存管理与高并发内存池系列】从 mmap 到 malloc:文件映射、匿名映射与 glibc 内存分配机制详解
linux·c语言·数据结构·数据库·c++·qt·链表
八解毒剂13 小时前
数据结构-平衡二叉树——对二叉搜索树的优化
数据结构·c++·算法
起床困难户57514 小时前
条款20:协助完成返回值优化
c++
啦啦啦啦啦zzzz14 小时前
算法总结(二分查找、双指针)
c++·算法