java重复调用函数_Java:重复调用函数会导致性能提升的原因是什么?

当我遇到一个奇怪的结果时,我正在做一些关于对象分配的性能测试.我有以下

java代码:

public static long TestMethod(){

int len = 10000000;

Object[] obs = new Object[len];

long t = System.nanoTime();

for (int i = 0; i < len; i++) {

obs[i] = new Object();

}

return System.nanoTime() - t;

}

public static void main(String... args) throws InterruptedException {

for(int i = 0; i < 10; i++){

System.gc();

System.gc();//Wait for the gc to be finished

Thread.sleep(1000);

System.out.println(TestMethod());

}

}

期望:

由于请求操作系统和热点增强的更大内存空间,第一次调用将比第二次调用慢.但第二和第三将几乎相同.

观察结果:

11284734000

799837000

682304000

304736000

380770000

392786000

374279000

381611000

379174000

407256000

在第三次和第四次迭代之间仍然有相当大的加速.是什么导致这种加速?在测试其他功能时,如何确保测量结果准确无误,在测量之前是否必须调用该功能四次以上?

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值