【JVM字节码指令逐步图解】4种常见i++ 与 ++i 的区别(下)

环境:jdk1.8
工具:javap
javap操作命令:javap -v xxx.class

博客文章地址

0x003 类型三

代码如下:

    public void difference() {
        int i = 10;
        i = i++;

        int j = 10;
        j = ++j;
    }

使用javap反编译一下得到如下信息:
在这里插入图片描述操作流程:
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

区别:

在这里插入图片描述
通过上图可以看出,i = i++j = ++j区别在于,前者先将局部变量表中的数据存入操作栈中,在将局部变量表中索引为1的数据增加1,然后将栈中数据存入局部变量表中索引1的位置,原来数据被覆盖,也就是先使用,在自增,只不过自增没有意义了;后者是先将局部变量表索引为2的值增加1,再将表中数据取出压入栈当中,最后再次存入局部变量表,后两步操作对值没有什么影响,也就是先自增,在使用

0x004 类型四

代码如下:

    public void difference() {
        int i = 10;
        int j = i++ + ++i;
    }

使用javap反编译一下得到如下信息:
在这里插入图片描述
操作流程:
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

在这里插入图片描述
描述:
在这里插入图片描述
整体流程是,将10存入局部变量表之后,先取局部变量表中的值(10)入栈,在将局部变量表中的值增加1(11)这是i++的操作】,在将局部变量表中的值增加1(12),取出局部变量表中的值(12)入栈,最后进行加和

发布了7 篇原创文章 · 获赞 1 · 访问量 265

猜你喜欢

转载自blog.csdn.net/weixin_46235241/article/details/104411311