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 相关文章推荐
javascript preload&amp;lazy load
May 13 Javascript
js特殊字符转义介绍
Nov 05 Javascript
jquery判断元素的子元素是否存在的示例代码
Feb 04 Javascript
jquery实现图片按比例缩放示例
Jul 01 Javascript
深入JavaScript高级程序设计之对象、数组(栈方法,队列方法,重排序方法,迭代方法)
Dec 01 Javascript
jQuery替换节点用法示例(使用replaceWith方法)
Sep 08 Javascript
通过js控制时间,一秒一秒自己动的实例
Oct 25 Javascript
详解Vue用自定义指令完成一个下拉菜单(select组件)
Oct 31 Javascript
webpack4简单入门实例
Sep 06 Javascript
微信小程序 wepy框架与iview-weapp的用法详解
Apr 10 Javascript
vue下canvas裁剪图片实例讲解
Apr 16 Javascript
openLayer4实现动态改变标注图标
Aug 17 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
php获取远程图片体积大小的实例
2013/11/12 PHP
PHP GD库生成图像的几个函数总结
2014/11/19 PHP
详解WordPress开发中wp_title()函数的用法
2016/01/07 PHP
php实现微信支付之企业付款
2018/05/30 PHP
PDO::inTransaction讲解
2019/01/28 PHP
使用Entrust扩展包在laravel 中实现RBAC的功能
2020/03/16 PHP
Nigma vs Alliance BO5 第二场2.14
2021/03/10 DOTA
鼠标移动到一张图片时变为另一张图片
2006/12/05 Javascript
Use Word to Search for Files
2007/06/15 Javascript
jquery+json实现的搜索加分页效果
2010/03/31 Javascript
JavaScript中也使用$美元符号来代替document.getElementById
2010/06/19 Javascript
javascript测试题练习代码
2012/10/10 Javascript
Extjs优化(一)删除冗余代码提高运行速度
2013/04/15 Javascript
jquery清空textarea等输入框实现代码
2013/04/22 Javascript
浅析js预加载/延迟加载
2014/09/25 Javascript
jQuery中closest和parents的区别分析
2015/05/07 Javascript
AngularJS基于factory创建自定义服务的方法详解
2017/05/25 Javascript
JavaScript实现图片拖曳效果
2017/09/08 Javascript
javascript计算渐变颜色的实例
2017/09/22 Javascript
详解Nuxt.js Vue服务端渲染摸索
2018/02/08 Javascript
微信小程序文字显示换行问题
2019/07/28 Javascript
layer.open弹层查看缩略图的原图,自适应大小的实例
2019/09/05 Javascript
通过PYTHON来实现图像分割详解
2019/06/26 Python
详解numpy矩阵的创建与数据类型
2019/10/18 Python
Pytorch 中retain_graph的用法详解
2020/01/07 Python
Python单链表原理与实现方法详解
2020/02/22 Python
django model 条件过滤 queryset.filter(**condtions)用法详解
2020/05/20 Python
如何在windows下安装配置python工具Ulipad
2020/10/27 Python
CSS3自定义滚动条样式的示例代码
2017/08/21 HTML / CSS
浅谈css3新单位vw、vh、vmin、vmax的使用详解
2017/12/01 HTML / CSS
日本最大的药妆连锁店:Matsukiyo松本清药妆店
2017/11/23 全球购物
HTC VIVE美国官网:VR虚拟现实眼镜
2018/02/13 全球购物
应征英语教师求职信
2013/11/27 职场文书
出差报告范文
2014/11/06 职场文书
投资合作意向书范本
2015/05/08 职场文书
Mysql binlog日志文件过大的解决
2021/10/05 MySQL