首页 > 后端开发 > C++ > 正文

c++中的移动构造函数何时被调用_c++ move semantics深入解析【C++11】

冰火之心
发布: 2025-12-20 17:23:02
原创
527人浏览过
移动构造函数在C++11后用于高效转移临时或显式标记为可移动对象的资源。典型触发场景包括:用右值初始化新对象、函数返回局部对象(未被RVO优化时)、容器插入临时对象或显式std::move、throw/catch中抛出支持移动的临时对象;不触发的情况有:直接构造临时对象、C++17起拷贝初始化强制省略、const左值引用传参、const左值加std::move后无匹配移动构造函数;std::move仅作类型转换,不执行移动操作,实际是否移动取决于是否存在可用的T&&重载;移动后源对象处于有效但未指定状态,可析构或赋值,但不可依赖其原值。

c++中的移动构造函数何时被调用_c++ move semantics深入解析【c++11】

移动构造函数在C++11及以后版本中,当一个对象需要“接管”另一个临时或明确标记为可移动对象的资源(如动态内存、文件句柄等)时被调用,核心前提是:源对象不再需要其资源,且能安全地被“掏空”。

触发移动构造函数的典型场景

编译器会在以下情况自动选择移动构造函数(前提是该函数存在且未被删除,且不违反访问控制):

  • 用一个右值(如临时对象、std::move包装的左值)初始化新对象:MyClass a(std::move(b));MyClass a(MyClass());
  • 函数返回局部对象(满足RVO条件时可能被优化掉,但未优化时会触发移动):MyClass create() { return MyClass(); }auto x = create();
  • 向容器插入临时对象或使用std::vector::push_back(std::move(obj))等显式移动操作
  • throw/catch中抛出临时对象,且异常对象类型支持移动(非const左值引用捕获除外)

移动构造函数不会被调用的常见误解

不是所有“看起来像移动”的操作都会调用它:

  • 直接初始化临时对象本身(如MyClass())不调用移动,只调用普通构造函数
  • 拷贝初始化写法MyClass a = MyClass();在C++17前可能触发移动(也可能被优化),C++17起强制省略拷贝/移动(guaranteed copy elision),不调用任何构造函数
  • 传入const左值引用参数(如void f(const MyClass&))不会触发移动——它走的是const引用绑定,跟移动无关
  • 源对象是const左值(如const MyClass x;),即使加std::move(x),也只会匹配const右值引用(如果定义了),否则退化为拷贝(因const T&&无法绑定非常量移动构造函数)

手动触发移动的关键:std::move的作用

std::move本身不移动任何东西,它只是一个强制类型转换工具,把左值转换为对应类型的右值引用(xvalue),从而让重载解析有机会选中移动构造函数或移动赋值运算符:

Supermeme
Supermeme

Supermeme是一个AI驱动的Meme生成器,可以快速生成有趣的Meme梗图

Supermeme 114
查看详情 Supermeme

立即学习C++免费学习笔记(深入)”;

  • 它等价于static_cast(expr),不改变实参内容,也不调用任何函数
  • 只有目标类型确实提供了接受T&&的移动构造函数,且该函数可访问、未被删除,移动才会真正发生
  • 对内置类型(如int)或没有自定义移动操作的类,std::move后仍走拷贝——因为移动语义是“可选优化”,不是强制行为

移动后源对象的状态:有效但未指定

C++标准只要求移动后的源对象处于“有效但未指定状态”(valid but unspecified state):

  • 可以安全析构,也可以再次赋值(如obj = other;),但不能假设其仍保有原值
  • 常见做法是将指针置为nullptr、size置为0、句柄设为-1等,确保后续使用(如析构)不会重复释放资源
  • 不要在移动后继续读取其数据成员(除非你明确定义了移动后的语义并文档化)

基本上就这些。移动语义不是黑魔法,本质是编译器根据值类别和可用重载,选择最高效的资源转移方式。写对移动构造函数的前提,是理解何时它会被选中、为何有时被跳过、以及移动之后你对对象还能做什么。

以上就是c++++中的移动构造函数何时被调用_c++ move semantics深入解析【C++11】的详细内容,更多请关注php中文网其它相关文章!

c++速学教程(入门到精通)
c++速学教程(入门到精通)

c++怎么学习?c++怎么入门?c++在哪学?c++怎么学才快?不用担心,这里为大家提供了c++速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号