javap命令分析java的i=i++,i=++i的底层实现
2013-07-11 09:29
796 查看
一直以来,虽然知道下面代码的结果是1,但是具体为什么是1,却不是很清楚,偶然在网上看到了javap这个命令,可以查看java编译器生成的字节码。于是,就一目了然了。
先上代码:
我们都知道结果是1,但是具体底层是怎么运行的呢?
我们用javap命令来看一下:
看红色线框内的字节码:
我们可以看到,当执行iinc时,“increment local variable”,改变了本地变量的值,stack当中“No change”。然后第6步:istore_1,又把栈中的值存到本地变量中,栈中的值木有变,还是1,所以最后执行iload_1时,取本地变量时,取的还是1,所以最终结果是1.
下面我们把i=i++改为i=++i;再来看一下字节码:
这个字节码跟上一次的区别就在于,上一次是先执行iload再执行iinc,而这一次是先执行iinc,再执行iload,这样一来,就是自增之后,i为2,然后把2load到栈中,执行赋值语句时,再把栈中的2存到本地变量,这样i的最终结果就是2了。
先上代码:
public class Test{ public static void main(String[] args){ int i = 1; i = i++; System.out.println(i); } }
我们都知道结果是1,但是具体底层是怎么运行的呢?
我们用javap命令来看一下:
看红色线框内的字节码:
我们可以看到,当执行iinc时,“increment local variable”,改变了本地变量的值,stack当中“No change”。然后第6步:istore_1,又把栈中的值存到本地变量中,栈中的值木有变,还是1,所以最后执行iload_1时,取本地变量时,取的还是1,所以最终结果是1.
下面我们把i=i++改为i=++i;再来看一下字节码:
这个字节码跟上一次的区别就在于,上一次是先执行iload再执行iinc,而这一次是先执行iinc,再执行iload,这样一来,就是自增之后,i为2,然后把2load到栈中,执行赋值语句时,再把栈中的2存到本地变量,这样i的最终结果就是2了。
相关文章推荐
- Java中HashMap底层实现原理(JDK1.8)源码分析
- Java中HashMap底层实现原理(JDK1.8)源码分析
- HttpUrlConnection底层实现和关于java host绑定ip即时生效的设置及分析
- HttpUrlConnection底层实现和关于java host绑定ip即时生效的设置及分析
- HttpUrlConnection底层实现和关于java host绑定ip即时生效的设置及分析
- java集合的底层如何实现的,源码分析(未完成)
- HttpUrlConnection底层实现和关于java host绑定ip即时生效的设置及分析
- HttpUrlConnection底层实现和关于java host绑定ip即时生效的设置及分析
- 【GOF23设计模式】_命令模式_数据库事务机制底层架构实现_撤销和回复JAVA246
- Java线程池及其底层源码实现分析
- Java中HashMap底层实现原理(JDK1.8)源码分析
- Java中集合框架,Collection接口、Set接口、List接口、Map接口,已经常用的它们的实现类,简单的JDK源码分析底层实现
- Java中HashMap底层实现原理(JDK1.8)源码分析
- Java动态代理详解,以及底层JDK源码实现分析(基于Java8)。
- Java中HashMap底层实现原理(JDK1.8)源码分析
- (转载)Java中HashMap底层实现原理(JDK1.8)源码分析
- Java中HashMap底层实现原理(JDK1.8)源码分析
- Java面试绕不开的问题: Java中HashMap底层实现原理(JDK1.8)源码分析
- Java中HashMap底层实现原理(JDK1.8)源码分析
- Java中集合框架,Collection接口、Set接口、List接口、Map接口,已经常用的它们的实现类,简单的JDK源码分析底层实现