JavaScript之数组拼接的效率高低

前言

简单证明下不同数组拼接的效率问题,下面上结果(注意:我只在谷歌浏览器上进行了测试)
先说结论:arr.concat(array) > arr.push > arr[i] > [...arr] > arr.concat(i)

正文

<script>
        // 测试数组拼接的效率问题
        let n = 500000
        function test1() {
            let test_s = +new Date()
            let arr = []
            for (let i = 0; i < n; i++) {
                arr[i] = i
            }
            let test_e = +new Date()
            console.log('index:'+ (test_e - test_s) + 'ms       lenth:' + arr.length)
        }
        function test2() {
            let test_s = +new Date()
            let arr = []
            for (let i = 0; i < n; i++) {
                arr.push(i)
            }
            let test_e = +new Date()
            console.log('push:'+ (test_e - test_s) + 'ms        lenth:' + arr.length)
        }
        let con_arr = []
        for (let i = 0; i < n; i++) {
            con_arr[i] = i
        }
        function test4() {
            let test_s = +new Date()
            let arr = []
            arr = arr.concat(con_arr)
            let test_e = +new Date()
            console.log('concat(arr):'+ (test_e - test_s) + 'ms     lenth:' + arr.length)
        }
        function test5() {
            let test_s = +new Date()
            let arr = []
            arr = [...arr, ...con_arr]
            let test_e = +new Date()
            console.log('es6...:'+ (test_e - test_s) + 'ms      lenth:' + arr.length)
        }
        test1()
        test2()
        test4()
        test5()
    </script>

下面是几组数据的测试结果


n=10000
n=100000
n=500000
n=1000000
n=5000000
n=10000000
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • 第一部分:快速入门JS学习中的一些注意点:2018.8.16基础知识: 入门JavaScript是世界上最流行的脚...
    天山雪莲_38324阅读 3,579评论 0 1
  • Javascript有很多数组的方法,有的人有W3C的API,还可以去MDN上去找,但是我觉得API上说的不全,M...
    顽皮的雪狐七七阅读 9,795评论 0 6
  • 牛客网上面有一个关于js的自测,然后我看了一下原作者的github,记录一下解题过程吧。所以,对数组操作,不改变原...
    进击的前端阅读 3,674评论 0 1
  • 数组的定义 数组是按序号排列的一组值,每个值的位置都有编号(从0开始)。数组本质上是一种特殊的对象。它的键名是按(...
    Allin_Lin阅读 3,728评论 0 0
  • 这是周六随老婆逛街拍的一张照片,这是一家经营老酒的店,看到这个人物很有喜感,就随手拍下。 店家门联上的“相逢...
    四海新程阅读 3,153评论 2 7

友情链接更多精彩内容