当我们在学习前置++和后置++时,我们的老师和大多数课本上都写着,前置++是先自增后使用,后置++是先使用后自增,然后事实真的是这样吗?
解释过程
先看前置++
代码:
#include <stdio.h>
int main()
{
int a = 10;
int b = ++a;
return 0;
}
汇编:
看红色方框:
第一句,意思是开辟一个空间(a),将10放在该空间内;
第二句,意思是将开辟的那块空间(a)里的数据增加1;
第三句,意思是将那块空间里的数据(a)放到寄存器eax中;
第四句,意思是将寄存器eax中的值放到新开辟的一块空间(b);
从汇编上可以看出,前置++确实目前是先自增后使用,那么再看下面代码:
#include <stdio.h>
int main()
{
int a = 10;
++a;
return 0;
}
汇编:
第一句,意思是开辟一个空间(a),将10放在该空间内;
第二句,意思是将开辟的那块空间(a)里的数据增加1;
从汇编可以看出,这里仅自增了,并没有使用,当然原因也很简单,因为确实没有变量可以去使用它
接下来看后置++
代码:
#include <stdio.h>
int main()
{
int a = 10;
int b = a++;
return 0;
}
第一句,意思是开辟一个空间(a),将10放在该空间内;
第二句,意思是将那块空间里的数据(a)放到寄存器eax中;
第三句,意思是将rax+1(就是eax+1,就是10+1)放到寄存器edx中;(eax是rax的低32位,rax是64位寄存器)
第四句,意思是将edx(11)放到新开辟的一块空间(b);
第五句,意思是将eax(10)放回第一次开辟的空间(a)中;
从汇编可以看出,后置++是先将值放到一个寄存器(eax)中,然后值+1放到另一个寄存器中(edx),再然后将edx放回到原变量(完成自增),eax赋值到新变量(完成赋值)。并不是笼统的先使用后自增
再看下面代码:
#include <stdio.h>
int main()
{
int a = 10;
a++;
return 0;
}
汇编:
可以看到和前置++的第二张图完全一样,就是直接自增。
结论
前置++和后置++在单独使用时,也就是不进行对别的变量赋值等操作时,前置++和后置++是完全一样的(直接自增)。
而在需要赋值时:
前置++先完成自增(不需要用到寄存器),再将自增后的值放入到寄存器中,寄存器再将值放入到需要赋值到变量中;
后置++先将值放入到寄存器中,然后再将+1后的值放入到寄存器中,再分别将寄存器中的值放回到原变量(完成自增)和新变量(完成赋值)。