栈对象返回的问题 RVO / NRVO

简介: 具名返回值优化((Name)Return Value Optimization,(N)RVO)是一种优化机制,在函数返回对象时,通过减少临时对象的构造、复制构造及析构调用次数来降低开销。在C++中,通过直接在返回位置构造对象并利用隐藏参数传递地址,可避免不必要的复制操作。然而,Windows和Linux上的RVO与NRVO实现有所不同,且接收栈对象的方式也会影响优化效果。

栈对象返回的问题

RVO / NRVO

(具名)返回值优化((Name)Return Value Optimization,简称(N)RVO),是这
么一种优化机制:当函数需要返回一个对象的时候,如果自己创建一个临时对象用户返
回,那么这个临时对象会消耗一个构造函数(Constructor)的调用、一个复制构造函
数的调用(Copy Constructor)以及一个析构函数(Destructor)的调用的代价。

通过优化的方式,可以减少这些开销。

Windows 和 Linux 的 RVO 和 NRVO 是有区别的。

A foo()
{
    //    return A(); //不具名返回
    A a;
    return a;
    //具名返回
}
int main()
{
    foo();
}

在 main()函数调用 foo()之前,会在自己的栈帧中开辟一个临时空间,该空间的
地址作为隐藏参数传递给 foo(),在需要返回 A 对象时,就在这个临时空间上构造一个
A a,然后这个空间的地址再利用寄存器 eax 返回给 main()函数,这样 main()函数就
能获得 foo()函数的返回值了。

接收栈对象的方式不同,会影响优化效果

相关文章
|
2天前
|
C语言
【数据结构】栈和队列(c语言实现)(附源码)
本文介绍了栈和队列两种数据结构。栈是一种只能在一端进行插入和删除操作的线性表,遵循“先进后出”原则;队列则在一端插入、另一端删除,遵循“先进先出”原则。文章详细讲解了栈和队列的结构定义、方法声明及实现,并提供了完整的代码示例。栈和队列在实际应用中非常广泛,如二叉树的层序遍历和快速排序的非递归实现等。
40 9
|
1天前
|
存储
系统调用处理程序在内核栈中保存了哪些上下文信息?
【10月更文挑战第29天】系统调用处理程序在内核栈中保存的这些上下文信息对于保证系统调用的正确执行和用户程序的正常恢复至关重要。通过准确地保存和恢复这些信息,操作系统能够实现用户模式和内核模式之间的无缝切换,为用户程序提供稳定、可靠的系统服务。
20 4
|
24天前
|
算法 程序员 索引
数据结构与算法学习七:栈、数组模拟栈、单链表模拟栈、栈应用实例 实现 综合计算器
栈的基本概念、应用场景以及如何使用数组和单链表模拟栈,并展示了如何利用栈和中缀表达式实现一个综合计算器。
25 1
数据结构与算法学习七:栈、数组模拟栈、单链表模拟栈、栈应用实例 实现 综合计算器
|
5天前
|
算法 安全 NoSQL
2024重生之回溯数据结构与算法系列学习之栈和队列精题汇总(10)【无论是王道考研人还是IKUN都能包会的;不然别给我家鸽鸽丢脸好嘛?】
数据结构王道第3章之IKUN和I原达人之数据结构与算法系列学习栈与队列精题详解、数据结构、C++、排序算法、java、动态规划你个小黑子;这都学不会;能不能不要给我家鸽鸽丢脸啊~除了会黑我家鸽鸽还会干嘛?!!!
|
11天前
|
存储 消息中间件 NoSQL
Redis 数据结构与对象
【10月更文挑战第15天】在实际应用中,需要根据具体的业务需求和数据特点来选择合适的数据结构,并合理地设计数据模型,以充分发挥 Redis 的优势。
47 8
|
24天前
初步认识栈和队列
初步认识栈和队列
53 10
|
18天前
数据结构(栈与列队)
数据结构(栈与列队)
15 1
|
23天前
|
存储 JavaScript 前端开发
为什么基础数据类型存放在栈中,而引用数据类型存放在堆中?
为什么基础数据类型存放在栈中,而引用数据类型存放在堆中?
61 1
|
19天前
【数据结构】-- 栈和队列
【数据结构】-- 栈和队列
13 0
|
24天前
探索顺序结构:栈的实现方式
探索顺序结构:栈的实现方式