📌 JS 高效生成数字数组:for 循环是最快的吗?最慢的方法竟然是它?

📖 简介

在 JavaScript 中,我们经常需要生成从 1n 的数字数组。常见的方法包括 for 循环、Array.fromfill + map 以及 new Array().map()等。但在实际应用中,不同方法的性能差异如何?最传统的 for 循环真的最快吗?而最慢的方法又是哪一个?本篇文章将通过性能测试深入探讨这些问题,并给出最优解。


📌 摘要

  • 目标 :对比 JavaScript 中几种生成 1 ~ n 数组的方法,找出最高效和最慢的方案。
  • 方法for 循环、Array.fromfill + mapnew Array().map() 等。
  • 结果for 循环在大数据量情况下最优,而某种常见方法的性能表现却意外最差!
  • 适用场景:不同方法适用于不同需求,本文将给出推荐方案。

📌 正文

🚀 1. 代码实现

在 JavaScript 中,生成 1 ~ n 数组的方法有很多,我们挑选其中 5 种常见方式进行对比。

javascript 复制代码
const num = 1000000; // 100万数据量

// 方法 1:Array.from
function generateArray1(num) {
  return Array.from({ length: num }, (_, index) => index + 1);
}

// 方法 2:new Array() + map
function generateArray2(num) {
  return new Array(num).fill(0).map((_, index) => index + 1);
}

// 方法 3:for 循环(最高效)
function generateArray3(num) {
  const result = [];
  for (let i = 1; i <= num; i++) {
    result.push(i);
  }
  return result;
}

// 方法 4:fill() + map()
function generateArray4(num) {
  return Array(num)
    .fill()
    .map((_, index) => index + 1);
}

// 方法 5:展开运算符 + map
function generateArray5(num) {
  return [...new Array(num)].map((_, index) => index + 1);
}

// 性能测试
console.time('Array.from');
generateArray1(num);
console.timeEnd('Array.from');

console.time('new Array + map');
generateArray2(num);
console.timeEnd('new Array + map');

console.time('for loop');
generateArray3(num);
console.timeEnd('for loop');

console.time('fill + map');
generateArray4(num);
console.timeEnd('fill + map');

console.time('Array + map');
generateArray5(num);
console.timeEnd('Array + map');

📊 2. 性能测试结果

我们在 Chrome 浏览器(V8 引擎)上运行测试,得到如下结果(时间单位:ms):

方法 代码实现 执行时间(ms)
方法 3 for 循环 🏆 最快
方法 1 Array.from 较快
方法 2 new Array().fill().map() 一般
方法 4 Array(num).fill().map() 一般
方法 5 [...new Array()].map() 最慢

(具体测试数据在不同环境下可能有所不同,建议自行测试验证。)


📌 3. 结果分析

for 循环(方法 3):最高效

  • 原因 :直接使用 push 添加元素,避免了 fill()map() 额外的遍历。
  • 适用场景:大数据量时建议使用。

Array.from(方法 1):较快

  • 原因Array.from 是优化过的底层实现,直接创建数组并填充数据。
  • 适用场景 :代码简洁,性能接近 for 循环。

⚠️ fill + map(方法 2、4):性能一般

  • 原因fill() 需要预填充数组,再 map() 遍历一次,导致多了一次迭代。
  • 适用场景:适用于小规模数据,避免大规模使用。

[...new Array()].map()(方法 5):最慢

  • 原因 :扩展运算符 ... 会创建一个新的数组,再 map() 遍历,额外的内存分配使其成为最慢的方法。
  • 适用场景 :❌ 不建议使用,性能损失严重。

📌 4. 结论与推荐

需求 推荐方法
最佳性能(大数据量) for 循环
代码简洁 + 高性能 Array.from
适用于小规模数据 ⚠️ fill + map
❌ 避免使用 [...new Array()].map()

🔥 总结:

  • for 循环是最快的,适用于大规模数据处理。
  • Array.from 代码最简洁,适用于大部分场景。
  • fill + map 方法适用于小数据量,但性能稍逊。
  • 避免使用 [...new Array()].map(),它是最慢的!

你是否有更快的方法?欢迎留言讨论!🚀

相关推荐
RadiumAg1 小时前
记一道有趣的面试题
前端·javascript
yangzhi_emo1 小时前
ES6笔记2
开发语言·前端·javascript
yanlele1 小时前
我用爬虫抓取了 25 年 5 月掘金热门面试文章
前端·javascript·面试
中微子2 小时前
React状态管理最佳实践
前端
烛阴2 小时前
void 0 的奥秘:解锁 JavaScript 中 undefined 的正确打开方式
前端·javascript
中微子3 小时前
JavaScript 事件与 React 合成事件完全指南:从入门到精通
前端
Hexene...3 小时前
【前端Vue】如何实现echarts图表根据父元素宽度自适应大小
前端·vue.js·echarts
初遇你时动了情3 小时前
腾讯地图 vue3 使用 封装 地图组件
javascript·vue.js·腾讯地图
dssxyz3 小时前
uniapp打包微信小程序主包过大问题_uniapp 微信小程序时主包太大和vendor.js过大
javascript·微信小程序·uni-app
天天扭码3 小时前
《很全面的前端面试题》——HTML篇
前端·面试·html