当前位置: 首页 > news >正文

C++进阶:1. 引用折叠规则

C++ 引用折叠规则

引用折叠(Reference Collapsing)是 C++ 模板和auto类型推导中的核心隐式规则,专门解决多层引用嵌套(如T& &T&& &)的问题——C++ 语法不允许直接写“引用的引用”,编译器会通过引用折叠将多层引用化简为单层引用

一、核心规则

只有2 条铁律,所有嵌套引用最终都会被折叠成:

  1. 只要任意一层是左值引用(&),最终结果就是左值引用(&)
  2. 只有两层都是右值引用(&&),最终结果才是右值引用(&&)

简化表格:

嵌套写法折叠结果口诀
T& &T&有左则左
T& &&T&有左则左
T&& &T&有左则左
T&& &&T&&双右才右

注意:这是编译器自动执行的规则,你不能手动写T& &,但模板/auto推导时会自动生成。

二、规则的诞生背景

C++11 引入右值引用后,模板/auto推导会产生引用嵌套,例如:

template<typenameT>voidfunc(T&&param){}// 万能引用(Forwarding Reference)

当你传入左值/右值时,编译器会推导出嵌套引用,再触发折叠:

intx=10;func(x);// x 是左值 → T 推导为 int& → T&& = int& && → 折叠为 int&func(10);// 10 是右值 → T 推导为 int → T&& = int&& → 无折叠,保持 int&&

三、最常见场景:万能引用 + 引用折叠

万能引用T&&/auto&&)的核心就是引用折叠,它能完美保留参数的左/右值属性:

1. 模板中的万能引用

template<typenameT>voidforward(T&&val){// T&& 是万能引用,推导后触发引用折叠}inta=5;forward(a);// 传入左值 int → T = int&// 类型:int& && → 折叠为 int&(左值引用)forward(10);// 传入右值 int → T = int// 类型:int&&(无折叠,右值引用)

2. auto 中的万能引用

auto&&x=a;// a 是左值 → auto 推导为 int&// 类型:int& && → 折叠为 int&auto&&y=10;// 10 是右值 → auto 推导为 int// 类型:int&&

四、完整推导示例

我们直接看编译器的推导+折叠全过程:

// 模板函数template<typenameT>voidtest(T&&arg){}// 测试1:传入左值 intintnum=20;test(num);// 推导步骤:// 1. T 推导为 int&// 2. T&& = int& &&// 3. 引用折叠 → int&// 测试2:传入右值 inttest(20);// 推导步骤:// 1. T 推导为 int// 2. T&& = int&&// 3. 无折叠 → int&&

五、关键作用:完美转发(std::forward)

引用折叠是std::forward(完美转发)的底层原理:

  • 它利用引用折叠规则,100% 保留参数的左值/右值属性
  • 让函数参数在传递过程中不丢失值类型,避免不必要的拷贝

示例:

#include<utility>template<typenameT,typename...Args>Tcreate(Args&&...args){// 完美转发:保留 args 的左/右值属性,靠引用折叠实现returnT(std::forward<Args>(args)...);}

六、总结(必背)

  1. 规则:有左则左,双右才右
  2. 触发场景:模板T&&auto&&(万能引用)的类型推导
  3. 核心目的:解决“引用的引用”语法非法问题,实现完美转发
  4. 结果:所有嵌套引用最终只会是&&&两种之一

总结

  1. 引用折叠是编译器自动化简嵌套引用的隐式规则;
  2. 核心口诀:有左则左,双右才右
  3. 它是万能引用和**std::forward完美转发**的底层基础。
http://www.jsqmd.com/news/932306/

相关文章:

  • 基于姿态传感器与Nintendo LABO的互动木偶发声系统实现
  • 从STM32无缝迁移到普冉PY32F003:以UART中断收发为例,对比HAL库异同
  • AI驱动智能合约开发:ChatGPT+Truffle+Infura+MetaMask全流程实战
  • 民谣网站|基于Springboot的民谣网站管理系统(源码+数据库+文档)
  • KMS智能激活终极指南:告别Windows和Office激活烦恼的完整解决方案
  • AI如何守护加密货币高额交易安全:从异常检测到实时防御
  • Sora 2水印去除技术白皮书(仅限首批内测开发者流通版):基于频域掩码+时序一致性修复的工业级方案
  • AI意识之谜:从整合信息理论到硅基困境与未来路径
  • WebToEpub:三步将网页小说转换为EPUB电子书的终极解决方案
  • 从伯德图斜率到阶跃响应:手把手教你用Matlab分析控制系统,并选择PD、PI还是PID校正
  • 跨可用区高可用云原生集群节点规划中关于 K8s Pod健康检查探针设计部署的架构思考
  • 告别卡顿!用Faster-Whisper在CPU上5分钟搞定中文语音转文字(附Tiny模型下载与转换)
  • 用2针排针自制纽扣电池座:零焊接快速原型供电方案
  • 别再瞎猜了!用 Javassist 给 G1/ZGC 装个“黑匣子”,GC 停顿秒级定位
  • 板级设备树驱动修改实战:从PWM到CAN,释放GPIO的完整指南
  • 从《信任的进化》到团队协作:如何避免‘不信任病毒’在敏捷开发中蔓延
  • 围绕 GPU共享与多租户隔离方案实现云原生多模型负载均衡与应急容灾的推理冷备架构设计
  • Cadence Allegro焊盘制作避坑指南:为什么你的不规则焊盘在出Gerber时“消失”了?
  • 从PCB布线到天线设计:工程师必懂的微带线实战要点(以ADS/SIwave为例)
  • 2026闭眼入!5款AI写作辅助平台亲测,治愈文献焦虑,初稿撰写快人一步
  • 2026年特氟龙输送带厂家推荐榜单:铁氟龙耐高温/食品级/防粘/环形/烘干线/耐酸碱输送带品牌精选 - 企业推荐官【官方】
  • Sora 2动态转场实战指南:从零搭建电影级镜头衔接工作流(含37个可复用Prompt结构)
  • 告别Appium!用AirtestIDE搞定安卓自动化测试,从环境配置到脚本录制保姆级指南
  • 广州天河区吊装搬运公司哪家好?2026 口碑 TOP5 推荐 - 从来都是英雄出少年
  • IoT设备内存擦除技术:原理、实现与优化
  • 2026年一键生成论文工具测评:5款神器从选题到排版全流程通关秘籍
  • 神经渲染的鲁棒性:从技术内核到产业落地的全面解析
  • 2026年PVC彩壳行业权威评测|主流品牌实力解析与工程采购选型指南 - 外贸老黄
  • Salt Player完整使用指南:掌握Android本地音乐播放的实用技巧
  • TensorFlow Lite端侧说话人识别实战:从模型轻量化到移动端部署