TOP

i++与++i 递增递减运算符的前置与后置
2019-08-14 00:08:29 】 浏览:41
Tags:递增 递减 运算 符的 前置 后置

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

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


i++与++i 递增递减运算符的前置与后置 https://www.cppentry.com/bencandy.php?fid=49&id=228521

】【打印繁体】【投稿】【收藏】 【推荐】【举报】【评论】 【关闭】 【返回顶部
上一篇石子合并问题--直线版 HRBUST - 1.. 下一篇Reliable Multicast Programming..