自增问题
直接上题!!
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 <init>()V
L0
LINENUMBER 1 L0
ALOAD 0
INVOKESPECIAL java/lang/Object.<init> ()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.<init> ()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