Java直接调用方法取值居然比用对象进行储存更快

本文探讨在32位JDK8环境下,通过get方法获取值与存储在final int变量中的值在执行效率上的差异。实验表明,在大规模重复执行下,直接调用方法的效率高于存储变量,但在较小规模执行中情况相反。

发现一件很奇怪的事:为什么通过get方法得到的值执行效率要比final int储存的要来的高?
32位JDK8环境
代码如下:(print和timer都是我自己写的方法,print可以输出多个不同类的对象,timer可以重复执行并计时,可以肯定功能不存在问题,也不会影响计时的性能)
private static int integer = 0;

List list = new ArrayList<>();
list.add(1)
final int i = list.get(0);
print(“get时间:”, timer(1000000000, () -> integer += list.get(0)));
print(“储存值时间”, timer(1000000000, () -> integer += i);
主要就这一段代码,重复十亿次,第一个输出大概是4300毫秒,第二个是4600毫秒,我试了好几次,浮动不大,而且没有一次储存值耗时能超过get方法。(明明get值用来+=还需要用Integer再转换一次)
使用Thread.sleep(0)来减缓执行速度以便观察时间后,在1万次到10万次数量级别,储存变量的执行速度会快过get方法,而在100万次级别时,两者不相上下。

我又测试了一下BigDecimal的intValue()和doubleValue()方法。
代码:
private static BigDecimal big = new BigDecimal(“1”);
private static int integer = 0:

final int i = big.intValue();
print(“get时间:”, timer(1000000000, () -> integer += big.intValue()));
print(“储存值时间”, timer(1000000000, () -> integer += i);

intValue可直接替换成doubleValue,只需改int类型为double即可
doubleValue耗时比intValue稍长,而在这里储存的变量性能就比方法要好一些了。
还有,在intValue测试中,如果储存变量i类型为double,运算性能会比int差一些。

print和timer代码之后会贴出来

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值