JS数组追加数组没有现成的函数,这么多年我已经习惯了a.push.apply(a, b);这种自觉得很酷的,不须要写for循环的写法,一直也没遇到什么问题,直到今天我要append的b是个很大的数组时才遇到了坑。javascript
a = new Array(); b = new Array(125624); a.push.apply(a, b);
以上的代码在mac的chrome下抛出了以下的异常html
Uncaught RangeError: Maximum call stack size exceeded
若是把数组改成b = new Array(125623);小一个元素竟然就行了,测试了一下其余浏览器也都有大数组才出错的问题,但不一样浏览器临界值还各异。java
搜索了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也是最快的chrome
这个小坑给了我两点思考:数组
一、有些花哨的用法如a.push.apply(a, b);仍是用于面试题装逼就行,实战上仍是多走老实路线省得遇到异常和性能的坑,例如小数量的如基于hightopo的这篇几十个节点的3D网络拓扑弹簧布局例子玩玩却是没问题,遇到真正大数据量如《基于HTML5的电信网管3D机房监控应用》中的HT for Web的这个3D大数据量性能例子才能考验出问题。浏览器
二、http://stackoverflow.com/questions/1374126 从stackoverflow找答案时不要仅盯着投票最多的,真理每每掌握在少数人手中,下图259票的回答是个坑,34票的才是最完美的分析:网络