js中for和while运行速度比较

今天在做排序的练习的时候发现冒泡排序和选择排序时间差距好大:

    for(let i=0;i<arr.length;i++){    //5000个数据大概260毫秒
        for(let j=0;j<arr.length-i;j++){
            if(arr[j]>arr[j+1]){
                let temp = arr[j];
                arr[j]=arr[j+1];
                arr[j+1]=temp;
            }
        }
    }
for(let i=0;i<arr.length;i++){    //5000个数据大概20毫秒
        let key = arr[i];
        let index = i;
        let j = i;
        while(j<arr.length){
                if(key>arr[j]){
                    key = arr[j];
                    index = j;
                }
            j++;
         }
        arr[index] = arr[i];
        arr[i]=key;
    }

冒泡和选择时间复杂都都是O(n^2),但时间却差了差不多10倍,找了半天以为算法写错了…………

然后把循环体都删了 发现时间还是不一样就开看了看光循环的时间对比

for(let i =0;i<5000;i++){
        for(let j=0;j<5000;j++){
        }
    }
let i = 0;
    while(i<5000){
        let j=0;
        while(j<5000){
            j++
        }
        i++;
    }

时间分别为50 和20感觉有差距

但敲了几次后又发现

for(let i =0;i<25000000;i++){
    }
let i = 0;
    while(i<25000000){
        i++;
    }

发现两个运行时间是差不多的…………

带循环体运行

for(let i =0;i<25000000;i++){
            a+=5;
        b+=10;
    }
let i = 0;
    while(i<25000000){
        a+=5;
        b+=10;
        i++;
    }

发现又存在执行时间上的差距了。

总结:for和while循环的时间应该是差不多的 但执行循环体的时间貌似有差距

时间: 2024-11-08 18:21:06

js中for和while运行速度比较的相关文章

什么是ES5?js中的&#39;use strict&#39;是什么?目的是什么?

什么是ES5? ECMA Script5:ECMA(欧洲计算机制造联合会)的第五次改版,2009年. js中的'use strict'是什么? js的严格模式 目的: ①添加更多报错的场合,消除代码的一些不安全之处,保证代码运行的安全. ②提高编辑器效率,提高运行速度. ③为新版本的JavaScript做铺垫. 补充缺点: ①IE9及以下都不支持. ②在工作中,js代码都会进行压缩,有一些文件没有使用严格模式,而现在的文件使用了严格模式,当压缩后,新文件的'use strict'就到了文件的中间

java使用htmlunit工具抓取js中加载的数据

htmlunit 是一款开源的java 页面分析工具,读取页面后,可以有效的使用htmlunit分析页面上的内容.项目可以模拟浏览器运行,被誉为java浏览器的开源实现.这个没有界面的浏览器,运行速度也是非常迅速的.采用的是Rhinojs引擎.模拟js运行. 说白了就是一个浏览器,这个浏览器是用Java写的无界面的浏览器,正因为其没有界面,因此执行的速度还是可以滴,HtmlUnit提供了一系列的API,这些API可以干的功能比较多,如表单的填充,表单的提交,模仿点击链接,由于内置了Rhinojs

js中获取时间new date()的用法

js中获取时间new date()的用法 获取时间:   var myDate = new Date();//获取系统当前时间 获取特定格式的时间: 1 myDate.getYear(); //获取当前年份(2位) 2 myDate.getFullYear(); //获取完整的年份(4位,1970-????) 3 myDate.getMonth(); //获取当前月份(0-11,0代表1月) 4 myDate.getDate(); //获取当前日(1-31) 5 myDate.getDay();

JS中的运算符&amp;JS中的分支结构

一.JS中的运算符 1.算术运算(单目运算符) + 加.- 减.* 乘./ 除.% 取余.++ 自增.-- 自减 >>> +:有两种作用,连接字符串/加法运算.当+两边全为数字时,进行加法运算: 当+两边有任意一边为字符串时,起连接字符串的作用,连接之后的结果为字符串 除+外,其余符号运算时,会先尝试将左右变量用Number函数转为数字 >>> /: 结果会保留小数点 >>> ++: 自增运算符,将变量在原有基础上+1: --: 自减运算符,将变量在原

Js中的数据属性和访问器属性

Js中的数据属性和访问器属性 在javaScript中,对象的属性分为两种类型:数据属性和访问器属性. 一.数据属性 1.数据属性:它包含的是一个数据值的位置,在这可以对数据值进行读写. 2.数据属性包含四个特性,分别是: configurable:表示能否通过delete删除属性从而重新定义属性,能否修改属性的特性,或能否把属性修改为访问器属性,默认为true enumerable:表示能否通过for-in循环返回属性 writable:表示能否修改属性的值 value:包含该属性的数据值.默

在Node.js中使用RabbitMQ系列二 任务队列

在上一篇文章在Node.js中使用RabbitMQ系列一 Hello world我有使用一个任务队列,不过当时的场景是将消息发送给一个消费者,本篇文章我将讨论有多个消费者的场景. 其实,任务队列最核心解决的问题是避免立即处理那些耗时的任务,也就是避免请求-响应的这种同步模式.取而代之的是我们通过调度算法,让这些耗时的任务之后再执行,也就是采用异步的模式.我们需要将一条消息封装成一个任务,并且将它添加到任务队列里面.后台会运行多个工作进程(worker process),通过调度算法,将队列里的任

js 中arguments的应用

在js中每个函数类都有一个Arguments对象实例arguments,.首先他不是一个数组,可以说算一个伪数组,但是用数组的索引形式也能获取到他的值,如 let len = arguments.length;表示函数参数的个数 arguments[0]表示第一个参数 在函数中使用它的好处就是这个函数在多处调用且参数有不是必须传递的,这样可以利用arguments来处理,解决了不需要的参数也要传递的问题 在实际应用中分装的函数中使用了一下,有不对的和需要改进的地方,还请大家多多指教,一起学习 e

js中,实现css格式的改变

js中,实现属性值的改变 (1)prop属性实现,html中标签的class属性值发生改变: 语法:$(元素标识).prop("class",类属性值); 例子:$("#num_"+currentId).prop("class","no-selected"); 类似的改变class属性: $("#index_" + index).removeClass("current"); $(&qu

JS中的循环结构、循环嵌套以及函数介绍

[循环结构的步骤]    *①声明循环变量    *②判断循环条件    *③执行循环体(while的{}中的所有代码)操作     *④更新循环变量    *     * 然后,循环执行②③④    *     *     * [JS中循环条件支持的数据类型]    * ①boolean:true 真     false   假    * ②string: 非空字符串为真       空字符串为假    * ③null/NaN/undefined:  全为假    * ④object:全为真