龙空技术网

i=i++深入解释

消消乐的生活百态 274

前言:

而今大家对“消消乐初始化的算法”可能比较注意,看官们都想要了解一些“消消乐初始化的算法”的相关内容。那么小编同时在网上汇集了一些对于“消消乐初始化的算法””的相关内容,希望同学们能喜欢,朋友们快快来学习一下吧!

一道基础的题目:

int i=0;

i=i++;

i=??

执行结果:0;

why??不应该是1吗?大脑中快速飞过计算步骤:

i初始化位0,题目中是i++,所以先进行i=i,i=0;

然后进行自加操作:i=1;

看似完美的步骤,其实是错的,难受哦。。。

那就往他祖坟上刨一下子:

int是基本类型,存在于栈中,但是变量名与值也是分开的。

那么开始把这个拆分一下:

i=i++查拆分

i++=i+1

去一个临时变量来代替i

temp = i;

又因为i是先执行后加,所以:

i = temp;

然后temp++;

画个图来说明一下:

通过class,来看他的执行流程:

通过观察编译后的执行顺序,可以清楚的看到i=i++;的执行流程。

---------------------

版权声明:本文为CSDN博主「骚小孩呀」的原创文章,遵循CC 4.0 by-sa版权协议,转载请附上原文出处链接及本声明。

原文链接:

标签: #消消乐初始化的算法