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 相关文章推荐
PNGHandler-借助JS让PNG图在IE下实现透明(包括背景图)
Aug 31 Javascript
js left,right,mid函数
Jun 10 Javascript
JQuery复制DOM节点的方法
Jun 11 Javascript
jQuery中用on绑定事件时需注意的事项
Mar 19 Javascript
bootstrap table动态加载数据示例代码
Mar 25 Javascript
input输入框内容实时监测(附代码)
Aug 15 Javascript
在Vue项目中引入腾讯验证码服务的教程
Apr 03 Javascript
jquery获取file表单选择文件的路径、名字、大小、类型
Jan 18 jQuery
Vue编写可显示周和月模式的日历 Vue自定义日历内容的显示
Jun 26 Javascript
jquery.tagsinput.js实现记录checkbox勾选的顺序
Sep 21 jQuery
vue 百度地图(vue-baidu-map)绘制方向箭头折线实例代码详解
Apr 28 Javascript
JavaScript展开运算符和剩余运算符的区别详解
Feb 18 Javascript
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
PHP4实际应用经验篇(6)
2006/10/09 PHP
PHP4实际应用经验篇(2)
2006/10/09 PHP
探讨php define()函数及defined()函数使用详解
2013/06/09 PHP
Yii2框架实现数据库常用操作总结
2017/02/08 PHP
JavaScript OOP面向对象介绍
2010/12/02 Javascript
JS正则中的RegExp对象对象
2012/11/07 Javascript
js简单的表格添加行和删除行操作示例
2014/03/31 Javascript
Javascript中的回调函数和匿名函数的回调示例介绍
2014/05/12 Javascript
jQuery中prev()方法用法实例
2015/01/08 Javascript
JS去除iframe滚动条的方法
2015/04/01 Javascript
javascript实时显示当天日期的方法
2015/05/20 Javascript
JavaScript中Math.SQRT2属性的使用详解
2015/06/14 Javascript
js模仿java的Map集合详解
2016/01/06 Javascript
js实现截图保存图片功能的代码示例
2017/02/16 Javascript
javascript数据结构中栈的应用之符号平衡问题
2017/04/11 Javascript
解决vue的router组件component在import时不能使用变量问题
2020/07/26 Javascript
[01:09:10]NB vs Liquid Supermajor小组赛 A组胜者组决赛 BO3 第一场 6.2
2018/06/04 DOTA
Django中使用locals()函数的技巧
2015/07/16 Python
python分布式环境下的限流器的示例
2017/10/26 Python
用十张图详解TensorFlow数据读取机制(附代码)
2018/02/06 Python
详解pyqt5 动画在QThread线程中无法运行问题
2018/05/05 Python
Python之list对应元素求和的方法
2018/06/28 Python
python读文件的步骤
2019/10/08 Python
Scrapy框架实现的登录网站操作示例
2020/02/06 Python
python+opencv边缘提取与各函数参数解析
2020/03/09 Python
Python3安装模块报错Microsoft Visual C++ 14.0 is required的解决方法
2020/07/28 Python
Python爬虫之Spider类用法简单介绍
2020/08/04 Python
Python JSON常用编解码方法代码实例
2020/09/05 Python
HTML5 标准将把互联网视频扔回到黑暗时代
2010/02/10 HTML / CSS
Linux机考试题
2015/10/16 面试题
少儿节目主持串词
2014/04/02 职场文书
个人课题方案
2014/05/08 职场文书
领导干部四风问题自我剖析材料
2014/09/25 职场文书
专项资金申请报告
2015/05/15 职场文书
劳动模范获奖感言
2015/07/31 职场文书
比较node.js和Deno
2021/04/27 Javascript