位置: 编程技术 - 正文

JS合并数组的几种方法及优劣比较(js合并两个数组并排序)

编辑:rootadmin

推荐整理分享JS合并数组的几种方法及优劣比较(js合并两个数组并排序),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:js组合数组,js数组合并的几种方法,js多数组合并,js组合数组,js中合并数组,js中合并数组,js中合并数组,js数组合并的几种方法,内容如对您有帮助,希望把文章链接给更多的朋友!

本文属于JavaScript的基础技能. 我们将学习结合/合并两个JS数组的各种常用方法,并比较各种方法的优缺点.

我们先来看看具体的场景:

很明显,数组 q 和 b 简单拼接的结果是:

concat(..)方法

最常见的用法如下:

如您所见, c 是一个全新的数组, 表示 q 和 b 这两个数组的组合, 但是 q 和 b 现在没用了是吧&#;

如果 q 数组有个元素, b 数组也有有个元素&#; 那么数组c现在就有个元素, 这种方式占用了2倍的内存.

“这没问题!”,你可能会觉得. 只要将 q 和 b 置空就行, 然后就会被垃圾回收,对吗&#;问题解决了!

额&#; 如果数组都很小,那自然没问题. 但对大型的数组,或需要多次重复处理时, 内存就被限制了, 它还需要进行优化.

循环插入

OK, 让我们把一个数组的内容加入到另一个中试试,使用 Array#push() 方法:

现在, q中存放了两个原始数组的内容(q + b).

看样子对内存优化做的不错.

JS合并数组的几种方法及优劣比较(js合并两个数组并排序)

但如果 q 数组很小而 b 又很大呢&#; 出于内存和速度的考虑,这时想把较小的 q 插入到 b 前面. 没问题,只要用 unshift() 方法代替 push() 即可, 对应的也要从大到小进行循环遍历:

实用技巧

悲催的是,for循环很土并且难以维护. 我们能做得更好吗&#;我们先试试 Array#reduce :

Array#reduce() 和 Array#reduceRight() 很高大上,但有点笨重,而且一般人也记不住. JS规范6 中的 => 箭头函数(arrow-functions) 能让代码量大大减少, 但需要对每个数组元素执行函数调用, 也是很渣的手段. 那么下面的代码怎么样呢&#;

BIG更高了,是吧!&#; 特别是 unshift() 方法不需要像前面那样考虑相反的顺序. ES6 的展开运算符(spread operator, 加 ... 前缀)就更高端了: a.push( ...b ) 或者 b.unshift( ...a )

但是,事实上这种方法还是太乐观了. 在这两种情况下,不管是将 a 或 b 传递给 apply() 作为第二个参数(apply方式调用Function时第一个参数在内部变成this,即context,上下文,作用域), 还是使用 ... 展开运算符的方式, 实际上数组都会被打散成为函数的 arguments .第一个主要的问题是,占用了双倍的内存(当然,是临时的!),因为需要将数组复制到函数栈之中. 此外,不同的JS引擎有不同的实现算法,可能会限制了函数可以传递的参数数量.

如果数组添加了一百万个元素, 那一定会超过函数栈所允许的大小, 不管是push() 或 unshift()调用. 这种方式只在几千个元素时可用,所以必须限制其不能超过一定范围.

注意: 你也可以试试 splice(), 肯定会发现他和 push(..)/unshift(..) 都是一样的限制.

一种选择是继续使用这种方法,但是采用分批次处理:

等等,我们损害了代码的可读性(甚至是性能!). 在我们放弃之前结束这个旅程吧.

总结

Array#concat() 是久经考验的方法, 用于组合两个(或多个)数组. 但他创建了一个新的数组,而不是修改现有的一个.

有很多变通的手法,但他们都有不同的优缺点,需要根据实际情况来选择.

上面列出了各种 优点/缺点,也许最好的(包括没有列出的)方法是 reduce(..) 和 reduceRight(..)

无论你选择什么,都应该批判性地思考你的数组合并策略,而不是把它当作理所当然的事情.

Javascript中this的用法详解 前些日子面试的时候用到了this,面试官说我的理解有点偏差,回来看了下书和一些博客,做了点测试,发现自己的理解的确有误1.全局变量应该是最常

js变量、作用域及内存详解 基本类型值有:undefined,NUll,Boolean,Number和String,这些类型分别在内存中占有固定的大小空间,他们的值保存在栈空间,我们通过按值来访问的。(1

深入理解javascript作用域和闭包 作用域作用域是一个变量和函数的作用范围,javascript中函数内声明的所有变量在函数体内始终是可见的,在javascript中有全局作用域和局部作用域,但

标签: js合并两个数组并排序

本文链接地址:https://www.jiuchutong.com/biancheng/385661.html 转载请保留说明!

上一篇:如何用JavaScript定义一个类(如何用u盘重装电脑系统)

下一篇:Javascript中this的用法详解(javascript中this的用法)

  • 税后债务资本成本计算公式 中级会计
  • 增值税税率改变后原项目的新增单价按哪个税率
  • 建筑企业简易计税和一般计税分开核算
  • 借款利息如何计算政策依据
  • 企业跨区变更地址需要多久
  • 工伤保险应该计入什么科目
  • 海关入库成功下一步干嘛
  • 小规模未达起征点销售额是多少
  • 不动产在建工程使用的外购物资可以抵扣吗
  • 企业取得财产转让收入确认时间
  • 物流公司赔付款会计分录
  • 自产产品对外捐赠需要缴纳增值税吗
  • 已认证已抵扣的发票对方要寄回吗
  • 往年的企业所得税季报可以更正吗
  • 建筑业简易征收的适用范围
  • 失控发票补完税还追究吗
  • 企业涉及应付利息的税金
  • win10闹钟设置方法
  • 软件开发并销售怎么做
  • 补交地税多少钱
  • 报销货物运输费需要什么凭证
  • 临时工工资应该找人力资源要吗
  • isahelp是什么进程
  • PHP:stream_get_transports()的用法_Stream函数
  • hbuilder怎么下载
  • 中央公园纽约的历史背景
  • 跨行政区域是跨省吗
  • 三万个字多久写完
  • css加载是异步的吗
  • 开出增值税发票一定要确认收入吗?
  • 自产产品对外捐赠销项税额怎么计算
  • yolov4tiny网络结构
  • 基于深度学习的图像超分辨率——综述
  • 计算机视觉竞赛很重要吗
  • 微信支付扫码支付顺序
  • 包装费包含什么
  • 购买汽车相关费用标准
  • 长期待摊费用的摊销期限应该是
  • 机器设备计提折旧纳税调整
  • 商品流通企业存货计价方法
  • sql server2014教程
  • 交易性金融资产公允价值变动怎么算
  • 专用发票与普通发票的区别有
  • 利息收入交税不
  • 发票当月没开
  • 收到房租租金下什么科目
  • 房租增值税专票税点
  • 股权稀释违法吗
  • 一般纳税人销售旧货可以开专票吗
  • 可以从公司公户直接支付给个人的款项有哪些
  • 税款滞纳金征收比率怎么算
  • 商品折扣计入哪个科目
  • 百旺金赋领回来的发票怎么读入
  • 应交增值税贷方余额表示什么
  • sql server多行添加
  • 微软宣布9款游戏退出XGP订阅
  • netdrive mac
  • ami 2.17.1254bios设置图解教程
  • ubuntu怎么用linux
  • 苹果电脑mac系统键盘无法找到
  • windowsxp的安装方法
  • linux系统监控软件
  • win7 64位系统提示"Windows7不能识别网络打印机"的故障原因及解决方法
  • 提示explorer.exe
  • GhostXP_SP3活力版V3.0_系统之家首发
  • linux 运行二进制文件
  • linux查看系统日志
  • Win8系统32位和64位哪个好应该如何选择
  • Cocos2dx ParticleEditor粒子编辑器
  • python中用input()函数接收到的数据为
  • jquery插件怎么用到自己的网站
  • jQuery.ajax实现根据不同的Content-Type做出不同的响应
  • eclipse出现an error has occurred
  • jqgrid loadcomplete
  • python中fd
  • 北京市国家税务局网站官网
  • 发票代码如何查询公司
  • 重庆沙坪坝区沙磁巷幼儿园
  • 小规模无票收入怎么报税
  • 按期申报和按次申报的区别
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设