for 和 filter 的效率哪个更高?

测试代码

假使我们现在需要对一个数组进行过滤,过滤掉其中为0的部分,用作比较的for循环和filter的代码如下:

var result = Array(500).fill(0)
var result1 = [...result]

console.time('for循环')
var a = []
for(var i=0; i<result.length; i++){
	if(result[i] === 1){
		a.push(result[i])
	}
}
console.timeEnd('for循环')

console.time('filter')
var s = result1.filter(item => item === 0)
console.timeEnd('filter')

使用chrome浏览器对其进行测试:

当测试数据全为1或者全为0时
类型数量时间
for循环100.011962890625 ms
filter100.02099609375 ms
for循环1000.053955078125 ms
filter1000.031005859375 ms
for循环10000.22900390625 ms
filter10000.05712890625 ms
for循环100002.56396484375 ms
filter100000.31396484375 ms
for循环1000003.81103515625 ms
filter1000004.214111328125 ms
for循环100000020.89599609375 ms
filter100000035.605224609375 ms

当数量级小于10,或者到10^5之后,for会比filter更快。数量级越高,差距越大。

当测试数据0,1各半时
类型数量时间
for循环100.010986328125 ms
filter100.022216796875 ms
for循环1000.0390625 ms
filter1000.029052734375 ms
for循环10000.10595703125 ms
filter10000.0419921875 ms
for循环100000.625244140625 ms
filter100000.182373046875 ms
for循环1000004.83203125 ms
filter1000002.058837890625 ms
for循环10000009.954833984375 ms
filter100000020.64892578125 ms

当数量级小于10或者到10^6之后,for会比filter更快。数量级越高,差距越大,如10^7时,filter 的时间是for的两倍。

新数组还是原数组

当然,这个比较的受限于这个for循环内部如何实现,你可以选择使用splice删除为0的数,也可以像我这样重新开一个数组。

for(var i=0; i<result.length; i++){
	if(result[i] === 0){
		result.splice(i,1)
		i--
	}
}
for循环: 11.97509765625 ms
filter: 174.044921875 ms

或者新开一个数组:
var a = []
for(var i=0; i<result.length; i++){
	if(result[i] === 1){
		a.push(result[i])
	}
}
for循环: 93.5498046875 ms
filter: 176.57080078125 ms

由于数量级增大,维护新开的数组需要耗时更多,对于这两种写法,如果不是一定要一个新数组的情况下,更推荐第一种,在原数组删除,相同数量级下,for循环的耗时更短,

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值