高频面试题-自增操作

自己先考虑下下面代码的结果:

package com.iamitman.first;

public class A_SelfIncrement {

    public static void main(String[] args) {
        int i = 1;
        i = i++;
        int j = i++;
        int k = i + ++i * i++;
        System.out.println("i=" + i);
        System.out.println("j=" + j);
        System.out.println("k=" + k);
    }
}

先容你思考一段时间

~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~

~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~

 

结果是:

i=4
j=1
k=11

难点在于:i=i++,这一项的执行后为:i=1,解释下原因:

当线程进入方法,局部变量表中会增加 i 变量,此时 i=1,计算 i++ 时,会往操作数栈中压入 i 的值即1,然后执行i++,此时局部变量表中的i+1=1+1=2,然后进行赋值操作,将操作数栈中的1赋值给 i ,i 就被覆盖成了1。

注意:在计算过程中,将表达式右侧的每个部分一次压入操作数栈中,最会进行统一计算,例如

 int k = i + ++i * i++;

在前面的两行执行后,此时i=2;

在执行这一行时,会将i=2,++i=3,i++=3依次压入操作数栈中,然后计算k的值,所以k = 2 + 3 * 3 = 11

又经过两次i自增,所以此时i=4。

你可能感兴趣的:(高频面试题)