i++ 和 ++i 效率的分析以及自定义类型的自增/自减运算符重载实例
From: http://blog.csdn.net/leo115/article/details/8101541
我们通常在写for循环 的时候,要实现变量 i 的自增 1 ;往往会在i++ 和++i中随便挑一种写,对于i++和++i的理解,我们往往停留在返回的值的不同,其实i++与++i在实现效率上也有一定的不同(不考虑编译器优化的原因)。
++i的实现效率更高
解释如下:
i++ (在C++中) 在实现的时候,系统会产生一个 local object class INT的临时变量 用于存储原有的数据供返回值用;
- ++i 的实现方式
- INT INT::operator++()
- {
- *this = *this +1;
- return *this;
- }
- i++的实现方式
- const INT INT::operator++(int)
- {
- INT oldvalue = *this;
- *this = *this+1;
- return oldvalue;
- }
所以从效率上来说 ++i 比 i++来的更有效率。
++i更高效
说明:
1、在不考虑编译器优化的条件下,前缀(++i)比后缀(i++)要少一步开辟临时变量的操作,所以前缀效率更高。
2、对于内置数据类型,由于编译器优化的原因,前缀和后缀的效率没什么差别。
例如:对于 int 型变量,编译器可以优化掉开辟临时变量这份多余的工作。
3、对于自定义的数据类型(类),我们在使用 自增 运算符的时候,需要重载 ++ 运算符,在重载的时候,后缀要开辟一个临时变量,所以前缀的效率要比后缀的更高。
Stl中迭代器使用的是 前缀
自定义类型的 前缀和后缀 的重载的 实现方式如下:
说明:如果考虑对 前缀(++i --i) 重载形式为 Type operator++() ;
后缀(i++ i--)的重载形式为:Type operator++(int); (这样定义是为了实现前缀与后缀的区分)
- #include <iostream>
- using namespace std;
- class PlusOne
- {
- public:
- int val;
- public:
- PlusOne(int a):val(a){}
- PlusOne operator++();
- PlusOne operator++(int);
- int getval() {return this->val;}
- };
- PlusOne PlusOne::operator++()
- {
- this->val += 1;
- cout<<this->val<<endl;
- return *this;
- }
- PlusOne PlusOne::operator++(int)
- {
- PlusOne tmp(*this);
- this->val += 1;
- cout<<this->val<<endl;
- return tmp;
- }
- int main()
- {
- PlusOne po(10);
- PlusOne po1 = ++po;
- PlusOne po2 = po++;
- cout<<"po1.val:"<<po1.getval()<<endl;
- cout<<"po2.val:"<<po2.getval()<<endl;
- return 0;
- }
运算结果如下:
i++ 和 ++i 效率的分析以及自定义类型的自增/自减运算符重载实例相关推荐
- php遍历数组哪个效率高,PHP遍历数组的三种方法及效率对比分析
PHP遍历数组的三种方法及效率对比分析 发布于 2015-03-04 21:55:27 | 129 次阅读 | 评论: 0 | 来源: 网友投递 PHP开源脚本语言PHP(外文名: Hypertext ...
- 【星云测试】精准测试的软件产品质量效率变化分析
2019独角兽企业重金招聘Python工程师标准>>> 精准测试的软件产品质量效率变化分析 伴随着软件规模的扩大和软件快速迭代的双重业务加速要求,软件质量控制的压力也越来越明显.但黑 ...
- [EntLib]微软企业库5.0 学习之路——第七步、Cryptographer加密模块简单分析、自定义加密接口及使用—上篇...
在完成了后,今天开始介绍企业库中的新模块:Cryptographer(加密模块),这个模块在日常的大多数项目的作用非常重要,例如:网站会员密码.身份证号.网站配置等,通过对信息进行加密可以保证项目数据 ...
- asp.net mvc源码分析-DefaultModelBinder 自定义的普通数据类型的绑定和验证
asp.net mvc源码分析-DefaultModelBinder 自定义的普通数据类型的绑定和验证 原文:asp.net mvc源码分析-DefaultModelBinder 自定义的普通数据类型 ...
- okhttp配置缓存策略_Okhttp缓存源码分析以及自定义缓存实现
原标题:Okhttp缓存源码分析以及自定义缓存实现 昨日,南京市公安局官方微博"平安南京"发布公告称,钱宝实际控制人张小雷因涉嫌违法犯罪于26日向当地警方投案自首.消息一出,迅速引 ...
- c语言编程效率的分析,C语言编程效率的分析.pdf
信息管理 年第 期 青海科技 2006 5 C语言编程效率的分析 卫 良 青海师范大学数学与信息科学系,青海 西宁 ) ( 810008 摘 要:文章结合实例探讨了 语言编程中的执行效率问题,并提出了 ...
- mysql bulk update_Django bulk_create()、update()与数据库事务的效率对比分析
下面以创建10000个对象为例进行测试: # 用for循环挨个创建,共花费37秒 for i in range(10000): name="String number %s"%i ...
- php高效遍历,PHP 遍历数组的三种方法及效率对比分析
PHP 遍历数组的三种方法及效率对比分析 本文实例分析了 PHP 遍历数组的三种方法及效率对比分享给大家供大家参考具体分析如下: 今天有个朋友问我一个问题 php 遍历数组的方法, 告诉她了几个顺便写 ...
- iOS底层-KVO分析与自定义
KVO分析与自定义 背景 准备 KVO一些细节 KVO探索分析 KVO 底层原理 小结: KVO自定义 自定义KVO要知道: 1,KVO是对setter方法进行观察,过滤实例方法 2,添加KVO(核心 ...
最新文章
- php post 文件,PHP响应post请求上传文件的方法_php技巧
- @程序员,第一批00后开始报考AI专业了
- Python机器学习(1)-- 自己设计一个感知机(Perceptron)分类算法
- 私有方法与静态私有方法_每个私有静态方法都是新类的候选人
- 第0次作业 -- 博客园作业提交方法
- Linux系统安装MySQL5.7,授权远程登陆
- 如何在Bash脚本中将Heredoc写入文件?
- 【转】Laplace 算子
- Windows Phone 7 异步编程模型
- bootstrap框架写手机端app模板也很漂亮
- html问号字符串,问号html
- 这篇文章应该在《新闻联播》连续报道一个月--武汉大学毕业生的反思
- 哪款蓝牙耳机的续航比较好?四款续航时间长的蓝牙耳机测评
- 数据仓库和数据挖掘方面比较好的书籍
- Java 遍历 Redis Hash key中所有数据
- 美在线教育商Lynda连续15年盈利 首度融资1亿美元
- xming Error: Can‘t open display:
- 完美的css背景图片全屏显示,能比例缩小,不留空白
- bulk es 删除_ES 批量操作 bulk
- iOS应用之微信支付集成-直接前端集成
热门文章
- python数据建模数据集_Python中的数据集
- blender视图缩放_如何使用主视图类型缩放Elm视图
- javascript创建类_如何在10分钟内使用JavaScript创建费用管理器
- 前端速成班_在此速成班中学习Go
- 如何使用EF Core在Blazor中创建级联的DropDownList
- 面向Tableau开发人员的Python简要介绍(第3部分)
- Alan Walker MV 合辑01 by defender
- PAT L1-048 矩阵A乘以B
- idea 调试技巧1
- [翻译]:怎样从C/C++代码中对C#进行回调