(面试)i++ / ++i 问题

自增问题

直接上题!!

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

数栈中的数据(仅供参考)


// class version 52.0 (52)
// access flags 0x21
public class incre {

  // compiled from: incre.java

  // access flags 0x1
  public ()V
   L0
    LINENUMBER 1 L0
    ALOAD 0
    INVOKESPECIAL java/lang/Object. ()V
    RETURN
   L1
    LOCALVARIABLE this Lincre; L0 L1 0
    MAXSTACK = 1
    MAXLOCALS = 1

  // access flags 0x9
  public static main([Ljava/lang/String;)V
   L0
    LINENUMBER 3 L0
    ICONST_1
    ISTORE 1
   L1
    LINENUMBER 4 L1
    ILOAD 1
    IINC 1 1
    ISTORE 1
   L2
    LINENUMBER 5 L2
    ILOAD 1
    IINC 1 1
    ISTORE 2
   L3
    LINENUMBER 6 L3
    ILOAD 1
    IINC 1 1
    ILOAD 1
    ILOAD 1
    IINC 1 1
    IMUL
    IADD
    ISTORE 3
   L4
    LINENUMBER 7 L4
    GETSTATIC java/lang/System.out : Ljava/io/PrintStream;
    NEW java/lang/StringBuilder
    DUP
    INVOKESPECIAL java/lang/StringBuilder. ()V
    ILOAD 1
    INVOKEVIRTUAL java/lang/StringBuilder.append (I)Ljava/lang/StringBuilder;
    LDC "\n"
    INVOKEVIRTUAL java/lang/StringBuilder.append (Ljava/lang/String;)Ljava/lang/StringBuilder;
    ILOAD 2
    INVOKEVIRTUAL java/lang/StringBuilder.append (I)Ljava/lang/StringBuilder;
    LDC "\n"
    INVOKEVIRTUAL java/lang/StringBuilder.append (Ljava/lang/String;)Ljava/lang/StringBuilder;
    ILOAD 3
    INVOKEVIRTUAL java/lang/StringBuilder.append (I)Ljava/lang/StringBuilder;
    INVOKEVIRTUAL java/lang/StringBuilder.toString ()Ljava/lang/String;
    INVOKEVIRTUAL java/io/PrintStream.println (Ljava/lang/String;)V
   L5
    LINENUMBER 8 L5
    RETURN
   L6
    LOCALVARIABLE args [Ljava/lang/String; L0 L6 0
    LOCALVARIABLE i I L1 L6 1
    LOCALVARIABLE j I L3 L6 2
    LOCALVARIABLE k I L4 L6 3
    MAXSTACK = 3
    MAXLOCALS = 4
}


一些理解

i ++ : ‘++’在左边可以简单地理解为 先使用后加1
++i : ‘++’在右边可以简单地理解为 先加1后使用

分析

理解数栈:
与局部变量表一样,均以字长为单位的数组。不过局部变量表用的是索引,操作数栈是弹栈/压栈来访问。操作数栈可理解为java虚拟机栈中的一个用于计算的临时数据存储区。

int i = 1;
i = i++;
int j = i++;
int k = i + ++i * i++;
第一行
给i 赋值为1
第二行
因为是‘i++’ ,首先将 i 等于1 入数栈,然后 i 自身加 1 等于 2,最后 i 被重新赋值为数栈中的值 1 。所以第一行后 i = 1 ;
第三行
因为是‘i++’ ,首先将 i 等于1 入数栈,然后 i 自身加 1 等于 2,最后就 j 被赋值为数栈中的值 1 。所以第一行后 i = 2  ;j = 1;
第四行
   [ 虽然有乘法但是,入数栈还是从左边开始 ]	此时第一个 i 为 2,压入数栈 ,因为是‘++i’ ,首先将 i 加1(局部变量区 3 ) ,然后入数栈(此时数栈中为 3),
   ‘i++’ 此时 i 为 3 ,压入数栈(此时数栈中为3),然后局部变量i 加 1 此时 i = 4,
   k 为 11 

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