关于i++,++i区别
问题:输出结果是什么?
#include<stdio.h>
main()
{
int a=0,b=1,c=2;
if(++a>0||++b>0)
++c;
printf("%d,%d,%d",a,b,c);
}
答案:113
基础概念不清晰的话,很容易算错成123,先简单解析下。
如果作为执行语句单列出来
(1)i++;(2)++i;
(1)和(2)是等价的,得到的结果都是i的原值增加1,
即i=i+1;
代码中的语句是作为判定条件,而非单独的执行语句。
if(++a>0||++b>0)
这就需要知道(++)参与程序执行的逻辑;
(3)++a>0 (4)++b>0 (5)++c;
程序执行时,执行顺序为由上至下,有左至右,(3)和(4)的逻辑关系为“或”关系,即(3)和(4)两者其中一个成立,(5)便可执行。因此当(3)的条件成立时,(4)不在参与条件判断,只有(3)不成立时,(4)才会进行执行参与判断。
由(3)可知++在a的左边,++先执行增1操作,然后执行是否大于零的判断逻辑,因此++a等价于a=a+1,亦可理解为++a的返回数是a+1,同时(4)的语句不在参与执行。
汇编程序如下:(仔细阅读汇编注释)
47: int a=0,b=1,c=2;
0x08000D42 2600 MOVS r6,#0x00
0x08000D44 2401 MOVS r4,#0x01
0x08000D46 2502 MOVS r5,#0x02
48: if(++a>0||++b>0)
//先做++增1操作,然后执行判断操作
0x08000D48 1C70 ADDS r0,r6,#1
0x08000D4A 1E06 SUBS r6,r0,#0
//R0寄存器的符号位是正号,程序跳转到地址(0x08000D56)
0x08000D4C DC02 BGT 0x08000D54
//执行++B>0的语句判断,条件为真,执行++c;否则BLE指令会跳过++c;
先做++增1操作,然后执行判断操作
0x08000D4E 1C60 ADDS r0,r4,#1
0x08000D50 1E04 SUBS r4,r0,#0
0x08000D52 DD00 BLE 0x08000D56
49: ++c;
0x08000D54 1C6D ADDS r5,r5,#1
程序中修改”if(++a>0||++b>0)“为
----- ”if(a++>0||++b>0)“后
源码如下
#include<stdio.h>
main()
{
int a=0,b=1,c=2;
if(++a>0||++b>0)
++c;
printf("%d,%d,%d",a,b,c);
}
其执行结果为:123
汇编代码如下
47: int a=0,b=1,c=2;
0x08000D42 2600 MOVS r6,#0x00
0x08000D44 2401 MOVS r4,#0x01
0x08000D46 2502 MOVS r5,#0x02
48: if(a++>0||++b>0)
//先执行判断操作,然后做++增1操作
0x08000D48 1E30 SUBS r0,r6,#0
0x08000D4A F1060601 ADD r6,r6,#0x01
//R0寄存器的符号位是正号,程序跳转到地址(0x08000D56)
0x08000D4E DC02 BGT 0x08000D56
//执行++B>0的语句判断,条件为真,执行++c;否则BLE指令会跳过++c;
0x08000D50 1C60 ADDS r0,r4,#1
0x08000D52 1E04 SUBS r4,r0,#0
0x08000D54 DD00 BLE 0x08000D58
49: ++c;
0x08000D56 1C6D ADDS r5,r5,#1
仔细比较两者代码差异,便可得出++和“或逻辑”的编译逻辑。