java 反编译结果不同_通过Java反编译揭开一些问题的真相

转自:http://www.importnew.com/20280.html

收藏待研究

博主在上一篇《Java语法糖之foreach》中采用反编译的形式进行探讨进而揭开foreach语法糖的真相。进来又遇到几个问题,通过反编译之后才了解了事实的真相,觉得有必要做一下总结,也可以给各位做一下参考。

相信很多朋友刚开始见到反编译后的内容的时候,肯定会吐槽:WTF!其实只要静下心来认真了解下,反编译也不过如此,Java字节码的长度为一个字节,顶多256条指令,目前,Java虚拟机规范已经定义了其中约200条编码值对应的指令含义。这里先用一个小例子来开始我们的征程(这里只是举例,要是在真实生活中看到这种代码,估计要骂娘了):

问题来了:最后y和z分别是多少?

看到y估计还能看看,看到z就晕乎乎的了,大家都知道i++是先取i值运算后对i进行自加,++i是先对i进行自加再运算。那么在一串组合里(y和z)怎么运用这个规则呢。

心急的朋友估计已经打开了编译器,跑一跑答案不就出来了,看着结果再反推一下就知道这个“游戏规则”了。

在C/C++和Java语言中都有这个事实:i++是先取i值运算后对i进行自加,++i是先对i进行自加再运算。但是这两(三)种语言跑出来的结果是不一样的。

在c/c++中(vs6):

646efe524bf53e042a92e6f23374f79d.png

运行结果:

138fa7802f23accb6223316183f0b051.png

在java中(eclipse),运行结果:2 19。

可以看到两(三)种语言虽然遵循了同样的自增规则但是输出的结果却不一样。这里不探讨c/c++的规则

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值