东莞网站建设设计公司uc浏览器网页版入口
一:前言
我们都知道,i++是先取值,后计算。++i是先计算,后取值。下面说下它的底层原理
二:原理
int i = 0;
i++;
Console.WriteLine(i);
结果是1
执行步骤是:
1.将常量0压入栈中
2.从栈中取出元素0,局部变量+1后再压入栈
3.输出时取栈顶元素1
无论是i++还是++i,底层执行都是一样的,因为这里并没有将++作为赋值表达式符号,底层也就视为只是将变量+1的操作,所以是没有区别的
int i = 0;
i = i++;
Console.WriteLine(i);
结果是0
执行步骤是:
1.将常量0压入栈中
2.从栈中取出元素0,将0入栈,然后再将局部变量i+1,此时i=1,接着赋值的时候将栈中元素赋给i,i赋值为0,再入栈
3.输出时取栈顶元素0
因为i++会创建临时变量,所以使用++i会减少一个变量的创建,但是这种性能上的优化对于一个值类型变量来说可忽略不计
int i = 0;
i = ++i;
Console.WriteLine(i);
结果是1
执行步骤是:
1.将常量0压入栈中
2.从栈中取出元素0,将局部变量i+1,此时i=1,再入栈
3.输出时取栈顶元素1
int i = 1;
i = ++i + i++;
Console.WriteLine(i);
结果是4
执行步骤是:
1.将常量1压入栈中
2.从栈中取出元素1赋值给i,将i+1后再入栈,此时i=2。2再次入栈,然后再将局部变量i+1,计算时取栈中的2和2相加结果为4,再赋值给i,再将i入栈
3.输出时取栈顶元素4
三:总结
i++先入栈再+1,++i先+1再入栈