i++与++i 递增递减运算符的前置与后置

2019-08-16 07:59:15来源:博客园 阅读 ()

新老客户大回馈,云服务器低至5折

i++与++i 递增递减运算符的前置与后置

C++Primer在132页的提示中说:除非必须,否则不用递增递减运算符的后置版本

很多教材都详细解释了递增递减运算符前置与后置的区别,我对他们的理解是:前置修改后直接赋值,而后置是先修改到临时变量,然后再赋值

下面的这份代码,第一个for循环使用后置版本,第二个使用前置版本,观察在实际使用中这两种样式的区别

for(int i=0;i<10;i++) cout<<i<<" ";
cout<<endl;
for(int i=0;i<10;++i) cout<<i<<" ";
cout<<endl;

运行结果:

0 1 2 3 4 5 6 7 8 9
0 1 2 3 4 5 6 7 8 9

输出结果完全相同,难道C++Primer在强行灌输作者的代码风格?

我们再来看一下下面这几行代码:

int i = 0,j  = 0;
cout<<i++<<" "<<++j<<endl;
cout<<i<<" "<<j;

运行结果:

0 1
1 1

现在意识到问题所在了么?上面提到了两种样式的工作方式,我们把他们写成伪代码,前置是i=i+1,而后置则是tmp=i+1,i=tmp

后置需要进行两倍于前置的操作次数,当然,也要消耗两倍的时间


原文链接:https://www.cnblogs.com/Ben-LaDeng/p/11324217.html
如有疑问请与原作者联系

标签:

版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有

上一篇:湫湫系列故事——设计风景线 HDU - 4514

下一篇:斜率优化dp学习笔记 洛谷P3915[HNOI2008]玩具装箱toy