天天看点

由i=i++ i=++i 写起

今天有网友问起 i++  ++i的问题  因为好久没有接触了 也不是特别理解其中的缘由  只记得当时老师教的时候 说让我们记住 "i++ 先使用 在自增 ++i 先自增在使用" 这句话

为了搞清缘由 反编译了下生成的class 文件

写了2个java 文件 分别命名为a.java  b.java c.java d.java

c.java

public class c{

public static void main(String args[]) {

int i = 0;

i = i++;

System.out.println(i);

}

}

d.java

public class d{

public static void main(String args[]) {

int i = 0;

i = ++i;

System.out.println(i);

}

咋一看 大多数人都以为最后的结果都是1.   其实是错误的。 

我们下面先看下反编译后的文件(红框内是不同部分)

由i=i++ i=++i 写起

我们以左图为例来进行分析(从main方法开始)

0: 将常数0插入栈    栈内容【0】

1: 将栈顶元素弹出 存入位置为1 的局部变量 (即i=0)   栈内容【】

2: 从位置为1 的局部变量取出元素 压人栈  栈内容【0】

3: 位置为1 的局部变量+1 此时i=1  栈内容【0】

6:  将栈顶元素弹出 存入位置为1 的局部变量  这时i的值又为0了 栈内容【】

10: 从位置为1 的局部变量取出元素 压人栈   栈内容【0】

11: 调用打印方法 输出栈顶内容

所以 最后结果为0

通过上面的对字节码的分析 可以得出

i=i++;   是先将i的值压人栈顶 能后在+1(此时i=1) 在能后将栈顶的值赋给i  虽能+1了  但是最后又被栈顶的值覆盖了 所以 还是0  

这行代码可以理解为:  int tmp = i; i++; i=tmp;

而i=++i 就不一样了 他是先+1 能后在入栈  在出栈。(上面的加粗标红部分)

所以在i 同为0 的情况下 最后的结果是

i=i++; ==>  0

i=++i; ==> 1