JavaScript中的console.profile()函数详细介绍


Posted in Javascript onDecember 29, 2014

编写JavaScript程序时,如果需要知道某段代码的执行时间,可以使用console.time()。不过,在分析逻辑较为复杂的JavaScript程序,试图从中找出性能瓶颈的时候,console.time()就不适用了 — 深入分析逻辑较为复杂的JavaScript程序的运行就意味着插入大量的console.time()语句,而这无疑是不可接受的。对于复杂逻辑的JavaScript程序调优,正确的方法是使用console.profile()。

浏览器支持

安装了Firebug插件的Firefox、Google Chrome以及Safari都支持console.profile()语句,最新版的IE和Opera也提供了Profile功能。在几大浏览器上console.profile()的使用大同小异,本文仅介绍Firebug中console.profile()的使用情况。值得注意的一点是:如果使用Firebug控制台来直接编写JavaScript实验代码,那么console.profile()是无效的。

console.profile()的使用

console.profile()的使用非常简单:在需要开始profile的地方插入console.profile(),在结束profile的地方插入console.profileEnd()即可。以下面的代码为例:

function doTask(){

    doSubTaskA(1000);

    doSubTaskA(100000);

    doSubTaskB(10000);

    doSubTaskC(1000,10000);

}

function doSubTaskA(count){

    for(var i=0;i<count;i++){}

}

 

function doSubTaskB(count){

    for(var i=0;i<count;i++){}

}

 

function doSubTaskC(countX,countY){

    for(var i=0;i<countX;i++){

        for(var j=0;j<countY;j++){} 

    }

}
console.profile();

doTask();

console.profileEnd();

在运行doTask()函数前执行console.profile(),doTask()函数运行完成后执行console.profileEnd(),这样即可收集到doTask()函数运行过程中的细节信息。在Firebug的控制台中可以看到:

JavaScript中的console.profile()函数详细介绍

从结果中可以看到:此次profile时间共计101.901ms,涉及5次函数调用。结果的默认标题是”Profile”,可以通过向console.profile()函数传入参数来进行自定义。比如,使用console.profile(“Test Profile”)即可在结果中将此次profile的标题改为”Test Profile”,这对于同时执行多个profile过程的情况下尤为有用。具体profile结果中各列的含义为:

1.Function。函数名。
2.Calls。调用次数。比如,在上面的例子中,doSubTaskA()函数被执行了2次。
3.Percent。该函数调用所消耗的时间在总体时间中所占的百分比。
4.Own Time。除去调用其它函数所消耗的时间,该函数本身的耗时数量。比如,在上面的例子中,doTask()无疑执行了很长时间,但是因为其耗时全部花在了对其它函数的调用上,因此其本身所耗时间并不多,仅为0.097ms。
5.Time。与Own Time相反,不考虑对其它函数的调用因素,计算函数的总耗时。在上面的例子中,doTask()函数执行了101.901ms。对于Time和Own Time,也可以得到一个结论:如果Time比Own Time数值要大,那么该函数内部就涉及了对其它函数的调用。
6.Avg。计算函数的平均总耗时,其计算公式为:Avg=Time/Calls。在上面的例子中,doSubTaskA()函数被执行了2次,其总耗时为1.054ms,因此其平均总耗时为0.527ms。
7.Min。对该函数调用的最小耗时。比如,在上面的例子中,doSubTaskA()函数被执行了2次,其最小耗时,也就是耗时较少的那次调用花掉了0.016ms。
8.Max。对该函数调用的最大耗时。比如,在上面的例子中,doSubTaskA()函数被执行了2次,其最大耗时,也就是耗时较多的那次调用花掉了1.038ms。
9.File。函数所在的JS文件。

Firebug中Profile按钮的使用

除了在JavaScript代码中插入console.profile()语句,Firebug还提供了Profile按钮以便动态实时地对页面中的JavaScript代码进行profile。该按钮位置为:

JavaScript中的console.profile()函数详细介绍

当需要进行profile时,可以按下该按钮,如果接下来的页面操作触发了任何JavaScript代码,Firebug将会对此进行记录。profile过程结束时只要再一次按下该按钮即可。其最终结果与插入console.profile()语句所得到的结果时一致的。

Javascript 相关文章推荐
键盘控制事件应用教程大全
Nov 24 Javascript
高效的获取当前元素是父元素的第几个子元素
Oct 15 Javascript
jQuery中用dom操作替代正则表达式
Dec 29 Javascript
JavaScript获取表单内所有元素值的方法
Apr 02 Javascript
微信小程序 教程之注册程序
Oct 17 Javascript
微信小程序 wx:for的使用实例详解
Apr 27 Javascript
深入理解node.js之path模块
May 03 Javascript
JavaScript截屏功能的实现代码
Jul 28 Javascript
React key值的作用和使用详解
Aug 23 Javascript
require.js 加载过程与使用方法介绍
Oct 30 Javascript
简单谈谈javascript高级特性
Sep 04 Javascript
js与jquery获取input输入框中的值实例讲解
Feb 27 jQuery
jQuery中element选择器用法实例
Dec 29 #Javascript
JavaScript中的console.time()函数详细介绍
Dec 29 #Javascript
JavaScript前端图片加载管理器imagepool使用详解
Dec 29 #Javascript
JavaScript版的TwoQueues缓存模型
Dec 29 #Javascript
浅谈重写window对象的方法
Dec 29 #Javascript
JavaScript中的console.log()函数详细介绍
Dec 29 #Javascript
深入分析原生JavaScript事件
Dec 29 #Javascript
You might like
破解图片防盗链的代码(asp/php)测试通过
2010/07/02 PHP
PHP实现查询手机归属地的方法详解
2017/04/28 PHP
jquery一句话全选/取消全选
2011/03/01 Javascript
js实现文本框选中的方法
2015/05/26 Javascript
jQuery Validate验证框架详解(推荐)
2016/12/17 Javascript
Angular directive递归实现目录树结构代码实例
2017/05/05 Javascript
jQuery自定义多选下拉框效果
2017/06/19 jQuery
详解基于node的前端项目编译时内存溢出问题
2017/08/01 Javascript
详解利用Angular实现多团队模块化SPA开发框架
2017/11/27 Javascript
vue.js中引入vuex储存接口数据及调用的详细流程
2017/12/14 Javascript
微信小程序中换行空格(多个空格)写法详解
2018/07/10 Javascript
使用 electron 实现类似新版 QQ 的登录界面效果(阴影、背景动画、窗体3D翻转)
2018/10/23 Javascript
原生JS实现弹幕效果的简单操作指南
2020/11/10 Javascript
基于python元祖与字典与集合的粗浅认识
2017/08/23 Python
python实现淘宝秒杀聚划算抢购自动提醒源码
2020/06/23 Python
python 实时得到cpu和内存的使用情况方法
2018/06/11 Python
Django csrf 两种方法设置form的实例
2019/02/03 Python
python实现二维数组的对角线遍历
2019/03/02 Python
Python实现的读取文件内容并写入其他文件操作示例
2019/04/09 Python
Python远程视频监控程序的实例代码
2019/05/05 Python
python 中值滤波,椒盐去噪,图片增强实例
2019/12/18 Python
基于python及pytorch中乘法的使用详解
2019/12/27 Python
如何在python开发工具PyCharm中搭建QtPy环境(教程详解)
2020/02/04 Python
10分钟理解CSS3 Grid布局
2018/12/20 HTML / CSS
Sam’s Club山姆会员商店:沃尔玛旗下高端会员制商店
2017/01/16 全球购物
查找廉价航班和发现新目的地:Kiwi.com
2019/02/25 全球购物
联想印度官方网上商店:Lenovo India
2019/08/24 全球购物
罗技美国官网:Logitech美国
2020/01/22 全球购物
回门宴新郎答谢词
2014/01/12 职场文书
《阳光》教学反思
2014/02/23 职场文书
公安学专业求职信
2014/07/27 职场文书
我的中国梦演讲稿400字
2014/08/19 职场文书
个人年底工作总结
2015/03/10 职场文书
在人间读书笔记
2015/06/30 职场文书
董事长秘书工作总结
2015/08/14 职场文书
vue-cli3.x配置全局的scss的时候报错问题及解决
2022/04/30 Vue.js