RVO:Return value optimization

本文介绍C++中的一种特殊优化技术——返回值优化(RVO),它允许编译器省略函数返回值产生的临时对象拷贝操作,即使拷贝构造函数有副作用也能应用此优化。

Return value optimization

From Wikipedia, the free encyclopedia

Jump to: navigation , search

Return value optimization , or simply RVO , is a C++ -specific compiler optimization technique that involves eliminating the temporary object created to hold a function 's return value.[ 1] It is particularly notable for being allowed to change the observable behaviour of the resulting program .[ 2]

Contents

[hide ]

[edit ] Summary

In general, the C++ standard allows a compiler to perform any optimization, as long as the resulting executable exhibits the same observable behaviour as if all the requirements of the standard has been fulfilled. This is commonly referred to as the as-if rule .[ 3] The term return value optimization refers to a special clause in the C++ standard that allows an implementation to omit a copy operation resulting from a return statement , even if the copy constructor has side effects ,[ 4] something that is not permitted by the as-if rule alone.[ 3]

The following example demonstrates a scenario where the implementation may eliminate one or both of the copies being made, even if the copy constructor has a visible side effect (printing text).[ 4] The first copy that may be eliminated is the one where first is copied into the function f 's return value . The second copy that may be eliminated is the copy of the temporary object returned by f to second .

 



Depending on the compiler , and the compiler's settings, the resulting program may display any of the following outputs:

Hello World!
Hello World!
Hello World!
<nothing>

Background

Returning an object of builtin type from a function usually carries little to no overhead, since the object typically fits in a CPU register . Returning a larger object of class type may require more expensive copying from one memory location to another. To achieve this, an implementation may create a hidden object in the caller's stack frame , and pass the address of this object to the function. The function's return value is then copied into the hidden object.[ 5] Thus, code such as this:


 

May generate code equivalent to this:


 

which causes the Data object to be copied twice.

In the early stages of the evolution of C++ , the language's inability to efficiently return an object of class type from a function was considered a weakness.[ 6] Around 1991, Walter Bright invented a technique to minimize copying; effectively replacing the hidden object and the named object inside the function with the object used to hold the result:[ 7]


 

Bright implemented this optimization in his Zortech C++ compiler.[ 6] This particular technique was later coined "Named return value optimization", referring to the fact that the copying of a named object is elided.[ 7]

[edit ] Compiler support

Return value optimization is supported on most compilers,[ 1] including Microsoft Visual C++ ,[ 8] g++ ,[ 9] and the Intel C++ Compiler .

However, there may be circumstances where the compiler is unable to perform the optimization. One common case is when a function may return different named objects depending on the path of execution: [ 8] [ 10] [ 5]


 

[edit ] Other forms of copy elision

Apart from the elision of the copy operation in a return statement, section 12.8, paragraph 15 of the C++ standard lists another case where copy elision is allowed, namely when a temporary object of class type is copied to an object of the same type.[ 4] This is also a very widely implemented optimization. As a result, copy-initialization is usually equivalent to direct-initialization in terms of performance, but not in semantics; copy-initialization still requires an accessible copy constructor .[ 11] The optimization can not be applied to a temporary object that has been bound to a reference. Example:

 

The C++ standard also mentions that a similar optimization may be applied to objects being thrown and caught ,[ 12] [ 13] but it is unclear whether the optimization applies to both the copy from the thrown object to the exception object , and the copy from the exception object to the object declared in the exception-declaration of the catch clause . It is also unclear whether this optimization only applies to temporary objects , or named objects as well.[ 14] Given the following source code:



 

A conforming compiler should therefore produce a program that prints "Hello World!" twice. In the upcoming C++ standard (C++0x ), the issues have been addressed, essentially allowing the same set of outputs as the first program.[ 14

根据原作 https://pan.quark.cn/s/459657bcfd45 的源码改编 Classic-ML-Methods-Algo 引言 建立这个项目,是为了梳理和总结传统机器学习(Machine Learning)方法(methods)或者算法(algo),和各位同仁相互学习交流. 现在的深度学习本质上来自于传统的神经网络模型,很大程度上是传统机器学习的延续,同时也在不少时候需要结合传统方法来实现. 任何机器学习方法基本的流程结构都是通用的;使用的评价方法也基本通用;使用的一些数学知识也是通用的. 本文在梳理传统机器学习方法算法的同时也会顺便补充这些流程,数学上的知识以供参考. 机器学习 机器学习是人工智能(Artificial Intelligence)的一个分支,也是实现人工智能最重要的手段.区别于传统的基于规则(rule-based)的算法,机器学习可以从数据中获取知识,从而实现规定的任务[Ian Goodfellow and Yoshua Bengio and Aaron Courville的Deep Learning].这些知识可以分为四种: 总结(summarization) 预测(prediction) 估计(estimation) 假想验证(hypothesis testing) 机器学习主要关心的是预测[Varian在Big Data : New Tricks for Econometrics],预测的可以是连续性的输出变量,分类,聚类或者物品之间的有趣关联. 机器学习分类 根据数据配置(setting,是否有标签,可以是连续的也可以是离散的)和任务目标,我们可以将机器学习方法分为四种: 无监督(unsupervised) 训练数据没有给定...
本系统采用微信小程序作为前端交互界面,结合Spring Boot与Vue.js框架实现后端服务及管理后台的构建,形成一套完整的电子商务解决方案。该系统架构支持单一商户独立运营,亦兼容多商户入驻的平台模式,具备高度的灵活性与扩展性。 在技术实现上,后端以Java语言为核心,依托Spring Boot框架提供稳定的业务逻辑处理与数据接口服务;管理后台采用Vue.js进行开发,实现了直观高效的操作界面;前端微信小程序则为用户提供了便捷的移动端购物体验。整套系统各模块间紧密协作,功能链路完整闭环,已通过严格测试与优化,符合商业应用的标准要求。 系统设计注重业务场景的全面覆盖,不仅包含商品展示、交易流程、订单处理等核心电商功能,还集成了会员管理、营销工具、数据统计等辅助模块,能够满足不同规模商户的日常运营需求。其多店铺支持机制允许平台方对入驻商户进行统一管理,同时保障各店铺在品牌展示、商品销售及客户服务方面的独立运作空间。 该解决方案强调代码结构的规范性与可维护性,遵循企业级开发标准,确保了系统的长期稳定运行与后续功能迭代的可行性。整体而言,这是一套技术选型成熟、架构清晰、功能完备且可直接投入商用的电商平台系统。 资源来源于网络分享,仅用于学习交流使用,请勿用于商业,如有侵权请联系我删除!
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值