关于JS数组追加数组采用push.apply的问题


Posted in Javascript onJune 09, 2014

a = new Array();
b = new Array(125624);                     
a.push.apply(a, b);

以上的代码在mac的chrome下抛出了如下的异常

Uncaught RangeError: Maximum call stack size exceeded

如果把数组改为b = new Array(125623);小一个元素居然就好了,测试了一下其他浏览器也都有大数组才出错的问题,但不同浏览器临界值还各异。

搜索了http://stackoverflow.com/questions/1374126/how-to-append-an-array-to-an-existing-javascript-array/17368101#17368101 发现也有人遇到这样的坑:

Array.prototype.extend = function (other_array) {
    /* you should include a test to check whether other_array really is an array */
    other_array.forEach(function(v) {this.push(v)}, this);   
}

给出的建议是老老实实用forEach,不仅可以避免大数组的异常问题,并且从性能角度考虑forEach也是最快的

关于JS数组追加数组采用push.apply的问题

这个小坑给了我两点思考:

1、有些花哨的用法如a.push.apply(a, b);还是用于面试题装逼就行,实战上还是多走老实路线免得遇到异常和性能的坑,例如小数量的如这篇的这个几十个节点的3D网络拓扑弹簧布局例子玩玩倒是没问题,遇到真正大数据量如这篇中的HT for Web的这个3D大数据量性能例子才能考验出问题。

2、http://stackoverflow.com/questions/1374126 从stackoverflow找答案时不要仅盯着投票最多的,真理往往掌握在少数人手中,下图259票的回答是个坑,34票的才是最完美的分析:

关于JS数组追加数组采用push.apply的问题

关于JS数组追加数组采用push.apply的问题

 

Javascript 相关文章推荐
JavaScript 学习初步 入门教程
Mar 25 Javascript
JavaScript将数据转换成整数的方法
Jan 04 Javascript
javascript实现动态改变层大小的方法
May 14 Javascript
jQuery实现自动与手动切换的滚动新闻特效代码分享
Aug 27 Javascript
JavaScript中数组Array.sort()排序方法详解
Mar 01 Javascript
jQuery实现返回顶部按钮和scroll滚动功能[带动画效果]
Jul 05 jQuery
es7学习教程之fetch解决异步嵌套问题的方法示例
Jul 21 Javascript
移动web开发之touch事件实例详解
Jan 17 Javascript
javascript实现的字符串转换成数组操作示例
Jun 13 Javascript
JS实现简单tab选项卡切换
Oct 25 Javascript
vue项目实现多语言切换的思路
Sep 17 Javascript
js实现鼠标切换图片(无定时器)
Jan 27 Javascript
javascript浏览器兼容教程之事件处理
Jun 09 #Javascript
jQuery学习笔记之toArray()
Jun 09 #Javascript
jQuery学习笔记之jQuery原型属性和方法
Jun 09 #Javascript
jQuery简易图片放大特效示例代码
Jun 09 #Javascript
js操作模态窗口及父子窗口间相互传值示例
Jun 09 #Javascript
jQuery学习笔记之jQuery.extend(),jQuery.fn.extend()分析
Jun 09 #Javascript
js利用prototype调用Array的slice方法示例
Jun 09 #Javascript
You might like
PHP多线程批量采集下载美女图片的实现代码(续)
2013/06/03 PHP
php缓冲 output_buffering的使用详解
2013/06/13 PHP
PHP.ini中配置屏蔽错误信息显示和保存错误日志的例子
2014/05/12 PHP
php实现的SESSION类
2014/12/02 PHP
php简单实现多语言切换的方法
2016/05/09 PHP
使用composer安装使用thinkphp6.0框架问题【视频教程】
2019/10/01 PHP
基于laravel where的高级使用方法
2019/10/10 PHP
JQuery EasyUI 加载两次url的原因分析及解决方案
2014/08/18 Javascript
JavaScript实现带缓冲效果的随屏滚动漂浮广告代码
2015/11/06 Javascript
利用jQuery插件imgAreaSelect实现图片上传裁剪(同步显示图像位置信息)
2016/12/02 Javascript
Angular实现一个简单的多选复选框的弹出框指令实例
2017/04/25 Javascript
JS面向对象的程序设计相关知识小结
2018/05/26 Javascript
解决Ant Design Modal内嵌Form表单initialValue值不动态更新问题
2020/10/29 Javascript
[47:21]Liquid vs TNC Supermajor 胜者组 BO3 第一场 6.4
2018/06/05 DOTA
[32:39]完美世界DOTA2联赛循环赛 Forest vs Inki BO2第一场 11.04
2020/11/04 DOTA
Python cookbook(数据结构与算法)找到最大或最小的N个元素实现方法示例
2018/02/13 Python
在Python中字典根据多项规则排序的方法
2019/01/21 Python
python实现翻译word表格小程序
2020/02/27 Python
matplotlib bar()实现百分比堆积柱状图
2021/02/24 Python
CSS3提交意见输入框样式代码
2014/10/30 HTML / CSS
bonprix匈牙利:女士、男士和儿童服装
2019/07/19 全球购物
在C中是否有模拟继承等面向对象程序设计特性的好方法
2012/05/22 面试题
C语言中break与continue的区别
2012/07/12 面试题
毕业生在校学习的自我评价分享
2013/10/08 职场文书
课改先进个人汇报材料
2014/01/26 职场文书
校庆活动方案
2014/03/31 职场文书
体育系毕业生求职自荐信
2014/04/16 职场文书
图书室标语
2014/06/21 职场文书
个人存款证明书
2014/10/18 职场文书
学生上课说话检讨书
2014/10/25 职场文书
文体活动总结
2015/02/04 职场文书
肖申克救赎观后感
2015/06/02 职场文书
2019暑期安全倡议书!
2019/06/27 职场文书
创业计划书之书店
2019/09/10 职场文书
使用Spring处理x-www-form-urlencoded方式
2021/11/02 Java/Android
Spring boot实现上传文件到本地服务器
2022/08/14 Java/Android