手机JAVA10000次for循环耗时_Java的一个循环效率问题

我写了一个简单,其中一个看似普通的循环却出乎了我的意料,是用Java写的。其中yz及pow的底数我现在改了一下://方法一:

double w = 0.0, yz = 1.234567;

for (int i = 0; i 

if (currents[i] > i2) {

w += yz * currents[i] * Math.pow(1.56, i0/currents[i]);

}

}

return w;

//方法二:

double w = 0.0, yz = 1.234567;

for (int i = pMax; i 

w += yz * currents[i] * Math.pow(0.89, i0/currents[i]);

}

return w;

代码如上,现在问题就是照我的理解方法二应该比方法一快一些才对,而进行了测试方法一需要114ms,方法二需要333ms(进行了多次测试取平均)

我现在不知道到底是什么原因,所以上来请教讨论一下,谢谢各位!

- -|||  没分

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值