前言:
而今大家对“消消乐初始化的算法”可能比较注意,看官们都想要了解一些“消消乐初始化的算法”的相关内容。那么小编同时在网上汇集了一些对于“消消乐初始化的算法””的相关内容,希望同学们能喜欢,朋友们快快来学习一下吧!一道基础的题目:
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版权协议,转载请附上原文出处链接及本声明。
原文链接:
标签: #消消乐初始化的算法