(面试)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 <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 
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值