關于JS數(shù)組追加數(shù)組采用push.apply的問題
a = new Array();
b = new Array(125624);
a.push.apply(a, b);
以上的代碼在mac的chrome下拋出了如下的異常
Uncaught RangeError: Maximum call stack size exceeded
如果把數(shù)組改為b = new Array(125623);小一個元素居然就好了,測試了一下其他瀏覽器也都有大數(shù)組才出錯的問題,但不同瀏覽器臨界值還各異。
搜索了http://stackoverflow.com/questions/1374126/how-to-append-an-array-to-an-existing-javascript-array/17368101#17368101 發(fā)現(xiàn)也有人遇到這樣的坑:
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,不僅可以避免大數(shù)組的異常問題,并且從性能角度考慮forEach也是最快的
這個小坑給了我兩點思考:
1、有些花哨的用法如a.push.apply(a, b);還是用于面試題裝逼就行,實戰(zhàn)上還是多走老實路線免得遇到異常和性能的坑,例如小數(shù)量的如這篇的這個幾十個節(jié)點的3D網絡拓撲彈簧布局例子玩玩倒是沒問題,遇到真正大數(shù)據(jù)量如這篇中的HT for Web的這個3D大數(shù)據(jù)量性能例子才能考驗出問題。
2、http://stackoverflow.com/questions/1374126 從stackoverflow找答案時不要僅盯著投票最多的,真理往往掌握在少數(shù)人手中,下圖259票的回答是個坑,34票的才是最完美的分析:
- JavaScript數(shù)組函數(shù)unshift、shift、pop、push使用實例
- js 數(shù)組操作之pop,push,unshift,splice,shift
- Js數(shù)組的操作push,pop,shift,unshift等方法詳細介紹
- JS數(shù)組合并push與concat區(qū)別分析
- JavaScript使用push方法添加一個元素到數(shù)組末尾用法實例
- JS數(shù)組方法push()、pop()用法實例分析
- JS數(shù)組方法shift()、unshift()用法實例分析
- JavaScript使用pop方法移除數(shù)組最后一個元素用法實例
- JS數(shù)組push、unshift、pop、shift方法的實現(xiàn)與使用方法示例
相關文章
JavaScript中Array.from()的超全用法詳解
Array.from方法用于將兩類對象轉為真正的數(shù)組:類似數(shù)組的對象(array-like?object)和可遍歷(iterable)的對象(包括?ES6?新增的數(shù)據(jù)結構?Set?和?Map),別忘記就來講講他的具體用法吧2023-03-03javascript圖片相似度算法實現(xiàn) js實現(xiàn)直方圖和向量算法
這篇文章主要介紹了javascript實現(xiàn)圖片相似度算法,大家參考使用吧2014-01-01