关于C++中使用++it还是it++的问题
我们经常使用for循环来遍历东西,循环变量可以前自增也可以后自增,发现对遍历结果没啥影响,但是该如何选择呢?
我们应该尽量使用前自增运算符而不是后自增运算符,即用 ++ Iter 代替 Iter++ 。
为什么要这么做,有什么有实际价值?下面我会详细解释。
前缀和后缀形式之间的区别是众所周知的。我希望它们内部结构的区别(告诉了我们运算法则)大家也是清楚的。如果你有使用过运算符重载的话,肯定已经意识到了。没有用过的话,我在这儿简单地解释一下(用过运算符重载的可以跳过下面关于运算符重载的例子)。
前自增运算符改变了对象的状态并返回对象改变后的状态,不需要创建临时对象。下面是前自增运算符的例子:
MyOwnClass& operator++()
{
++meOwnField;
return
(*this);
}
后自增运算符也改变了对象的状态但是返回的是对象改变前的状态,并且需要创建一个临时对象。下面是后自增运算符重载的例子:
MyOwnClass
operator++(int)
{
MyOWnCLass
tmp = *this;
++(*this);
return
tmp;
}
看到上面这段代码,你会发现有一个额外的操作,就是要创建一个临时对象,在实践中这点太重要了!
现在的编译器做代码优化的时候非常智能,如果没有用处,是不会随便创建临时对象的。这就是为什么在发布版中我们很难发现 i++ 和 ++ i 的区别。
但是在调试模式下进行程序调试的时候就是另一回事了,这时候你会看到性能上有很大差别。
举个例子,在这篇文章中,有一些例子可以估计调试版本中使用前自增和后自增运算符的代码运行时间,我们可以看到使用后缀形式所用时间几乎是前缀的四倍。
有人会说:”那又怎么样?反正发布版都是一样的。”,这种想法说对也对说不对也不对。通常我们会花更多的时间做单元测试和调试程序,所以大多数时间都在调试版本下工作,谁也不想浪费时间在那儿等吧?
关于“对于迭代器,我们是否应该用前自增运算符(++i)来代替后自增运算符(i++)?”这个问题,我想认真地回答: “是的,真应该这么做”。 你会发现在调试版本中速度大大提升。
如果迭代器很复杂的话,这么做的好处更是显而易见了。
这个错误是用静态代码分析工具 PVS-Studio 发现的,错误信息为:V803 性能下降。 如果iter是迭代器的话,使用前自增运算符会更高效,使用 ++iter 代替 iter++.
不管咋样,请用 ++ Iter 代替 Iter++,这是一个好的代码习惯。
最新文章
- 钉钉如何进行PC端开发
- hihocode 1077 : RMQ问题再临-线段树
- Linux内核分析之扒开系统调用的三层皮(上)
- 烟大 Contest1024 - 《挑战编程》第一章:入门 Problem A: The 3n + 1 problem(水题)
- No FileSystem for scheme: 远程访问HDFS找不到shceme
- jQuery 预习视频
- Hibernate初认识以及HelloWorld
- 第一篇博客关于Log4net的配置记录
- zxing源码分析——QR码部分
- BZOJ 3391: [Usaco2004 Dec]Tree Cutting网络破坏(搜索)
- 【java】对象克隆protected Object clone() throws CloneNotSupportedException
- 网站开发进阶(四)Tomcat Server处理一个http请求的过程
- 小计:Shopee批量删除修复~附脚本
- iis7.5做反向代理配置方法实例图文教程
- 隐藏状态栏,toolbar前面空格问题,editText圆角
- log4j2 Filter用法详解
- 【XSY2534】【BZOJ4817】树点涂色 LCT 倍增 线段树 dfs序
- go 编译:交叉编译&;编译执行过程
- 使用 R 语言挖掘 QQ 群聊天记录
- day11 匿名函数
热门文章
- 201871010110-李华《面向对象程序设计(java)》第八周学习总结
- LeetCode 153. Find Minimum in Rotated Sorted Array寻找旋转排序数组中的最小值 (C++)
- USACO Spinning Wheels
- MySQL字段类型 约束
- Linux学习笔记-第9天 与windows相同的分区知识
- 记一次linux下安装redis, 设置redis服务, 及添加环境变量
- cf1208G Polygons 欧拉函数
- [LeetCode] 907. Sum of Subarray Minimums 子数组最小值之和
- [LeetCode] 525. Contiguous Array 相连的数组
- [LeetCode] 12. Integer to Roman 整数转化成罗马数字