探讨i++和++i

本文通过具体的代码示例,详细分析了i++和++i在C/C++中的行为差异,特别是在条件判断语句中的表现,并澄清了一些常见的误解。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

探讨i++和++i

作者: Jiaping Gui 桂佳平 (Intel) (5 篇文章) 日期: 六月 11, 2012 在 3:11 下午

最近笔者在调试代码时发现自己在对++运算符的理解上不够深入,导致一个不应有的bug的出现。
在代码书中或课堂上我们都知道++i和i++在作为一个单独语句使用时没有区别,即相当于i=i+1; 而作为语句的一部分时,如a=++i; 和a=i++; ++i先执行加1操作,再执行赋值操作(因++在前),而i++是先执行赋值操作,再执行加1操作(因++在后)。但这种论述未将其中更深的运行机制讲出来,尤其是在if或while等判断语句中,下面对其进行探讨:

  1. 作为单独语句存在,如下面的两段代码:
    1. int i=0;  
    2. if(i++){...}  

    1. int i=0;  
    2. if(++i){...}  

    上面的条件判断代码虽然是以单独语句出现,但编译器将其等价于i++(或++i)>0,故在第一段代码中先执行i>0判定,再执行i++,因此条件体里的代码不被执行;而在第二段代码中先执行i=i+1,再执行i>0,因此条件里代码会被执行。

  2. 作为语句的一部分存在,如下面的一段代码:
    1. int i=4,j=3;  
    2. if((i++=j++)!=4){...}  

    上面的代码中括号()的优先级比!=的优先级高,但编译器仍然将++运算符最后执行。即先执行赋值语句i=j,然后判定(i=3)!=4成立,最后执行i++和j++,接下去执行条件体里代码。

综上可知当i++作为单独条件语句进行判定时,即使没有显示地声明与0的比较,编译器仍将加上与0的比较;当i++作为复合语句使用时,不管++是否在优先级更高的运算符中,++仍然最后才执行,即在当前所在语句操作执行之后。

分类: Android 开发Blog ChallengeUltrabook企业应用开发全国博客大奖赛全国大学生软件创新大赛专栏其他图形和视觉计算开放源代码虚拟化技术高校博客大奖赛 

如需了解英特尔软件产品相关的性能和优化选项,请参阅优化注意事项.

 评论 (10)

2012年06月12日 10:47 


mk1111
不是问题的问题,++ -- 的时间是以整个语句为衡量的
2012年06月26日 11:07 


齐晓明
if((i++=j++)!=4){...} 这句能编译过去么?。。。
++i:
T& operator ++ ()
{
++ T;
return T;
}
i++;
const A& operator ++ (int)
{
temp = T;
++ T;
return temp;
}
2012年06月26日 11:24 


ikarenator
“先行判定”的说法乃是错误。实际上是 ++i 返回了 i 的一个引用而 i++ 返回了 i 在改变前的一个拷贝。实际上 ++ 的操作总是在返回值之前就完成的。后面也是讹误。
2012年06月26日 18:21 


mt521
不错,可以试试
2012年06月26日 19:05 


megadeath
对于 
if((i++=j++)!=4)

i++怎么能作为左值呢?编译器不报错么?
2012年07月04日 07:20 


fyzzy1943
我就想知道,,谁没事闲的要这么写呢?
2012年07月11日 05:37 


toby
写得还可以,不过理解只是一种,就好像法律是不允许解释的,C语言也是一样。
无论怎么解释,只要规定中没有那么写,别人就可以有其他理解,而写编译器的人一旦和你的理解不同,就会产生问题。
因此,这种用法就是错误的种子。我觉得比错误更可怕!因为他可能发生在定稿5年以后的程序上……
2012年07月12日 19:55 


其实俺不是什么所谓的坏人
首先 BS下++ --不单独写一个语句的。
这种写法,自己给自己添麻烦不说,还给别人添麻烦。
2012年07月15日 06:45 


laciqs
“综上可知当i++作为单独条件语句进行判定时,即使没有显示地声明与0的比较,编译器仍将加上与0的比较”
这和++运算符无关,写个if(i)一样会比较,因为这是控制表达式。
另外,if((i++=j++)!=4){...} 这种写法不应该在project中出现的。
要想说探讨的i++和++i的话,从C语言上来说除了应该注意顺序点问题外没什么值得说是探讨的,从汇编层面上理解才能勉强说是探讨。
2012年07月18日 06:22 


匿名
不同的编译器有不同的实现,探讨这种东西纯粹是吃饱了撑着。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值