今天在论坛上看到一个网友问一个关于i++和++i的区别的问题,这个问题虽然很简单回答,但是都只是书本上和一些简单程序举例的解释说明,好像很少有网友给出具体的原理,也就是CPU的执行。虽然简单,但是很多C入门的网友依然对此困惑,我在论坛上答复了那个网友,而且把我答复的内容复制到了我的blog当中,希望对一些刚刚入门的网友有所帮助。
main()
{
int a,b;
a=++b;
a=b++;
}
当然这个程序没有任何意义,目的就是让你了解一下,++的执行。
把上面的程序转换成汇编以后是这样的(部分代码,但足以说明问题)
_main proc near
push si
push di
; ?debug L 4
inc si
mov di,si
; ?debug L 5
mov di,si
inc si
@1:
; ?debug L 6
pop di
pop si
ret
_main endp
现在我来说一下
inc si
;si是变量b,执行inc si的意思是,让si加1,也就是b=b+1的操作
mov di,si
;di是变量a,执行mov di,si的意思是,把si的值给了di,也就是把变量b的值给了变量a,完成了a=b操作
也就是说a=++b;用两句C语言语句来写是:
b=b+1;(或b++,++b都可以,我这里用b=b+1直观些,给初学者看)
a=b;
很明显上面两条指令实现了a=++b;的功能
在看下面两条指令
mov di,si
;这个跟上面的功能一样,是把si的值给了di,也就是a=b;
inc si
;同样si的值加1,实现了b=b+1;的功能
同样用C的两条语句写是:
a=b;
b=b+1;
上面两条语句等价于a=b++;
这样说来,想必应该更深入了解些了吧?
如果有不妥之处,请高手指点~!
>> 本文固定链接: http://www.vcgood.com/archives/964