频 道 直 达 - 新闻 - 培训 - 软件 - 教程 - 前沿 - 组网 - 系统应用 - 安全 - 编程 - 存储 - 操作系统 - 数据库 - 服务器 - 专题 - 产品 - 案例库 - 读书 - 博客 - BBS
51CTO.COM_中国最大的网络技术网站
找资料:

3.2.1 和普通Object初始化的性能比较

作者: 夏天 出处:电子工业出版社博文视点  2008-04-09 16:17    砖    好    评论   进入论坛
阅读提示:《JavaScript高级应用与实践》第三章讲了Object扩展和性能及Web应用之神兵利器,本文为typeof和constructor总结。本文和普通Object初始化的性能比较.

3.2  高性能初始化

由于JavaScript是解释执行的编程语言,它不像编译执行语言能对编译执行前的代码进行最大优化,因此写法就非常重要,我们往往需要从各个角度点点滴滴地进行优化。本节所讲的就是Object的优化初始化方法。

3.2.1  和普通Object初始化的性能比较
同样功能的两段代码,运行20 000次,我们就可以看出它们的性能差异,“莫因善小而不为”,同样,也不要因为性能差异不大,就不注意编码的性能。代码如下所示。

<html>
<head><meta http-equiv=content-type content=“text/html; charset=utf-8”>
<title>测试初始化Object的性能</title>
<style>
html,body,td,p,div,span,th
{
font-size:9pt;
}
</style>
</head>
<body>
<script type="text/javascript" language="JavaScript"
src="/jcore/resource /javascript/Jcore.js"></script>
<script type="text/javascript" language="JavaScript">
<!--

// 功能描述:本方法主要用来测试本书中的性能相关代码
// 返回信息:无返回
// 使用指南:new fnMyTest(function()
// { var szStr = new StringBuffer().append("good")
//  var szStr = new StringBuffer().append("good").
append(" just fine").append(" : summer").append(" xiatian")
// .append(9876).toString();
//   delete szStr;
// }, function()
// { var szStr = "good".append(" just fine").append(" : summer")
// var szStr = "good".append(" just fine").append(" : summer")
.append(" xiatian").append(9876).toString();
//   delete szStr;
// }, 500, "可以看出来,扩展的String更优于自己写的StringBuffer");
// 本方法将加入Jdebug.js,因此后面的章节不会出现这段代码了,请读者注意
// 应用范围:各种Web客户端和服务端开发
function fnMyTest(fnCode1, fnCode2, nRtCnt, s)
{
try{
var _this = this;
fnGetObjs('code1')[0].innerText = fnCode1.toString();
fnGetObjs('code2')[0].innerText = fnCode2.toString() + "\n\n// " + s;
fnGetObjs('tms')[0].innerText = nRtCnt;
fnMyTest._fnCode1 = fnCode1;
fnMyTest._fnCode2 = fnCode2;
fnMyTest.ovcnt = 0;
// aList的功能是返回值为从1到11的数组
[].aList(1, 11).each(function(n)
{
   window.setTimeout(function(){myTestRun(n, nRtCnt)}, 64);
});
Msg("多线程启动完毕");
}catch(e){fnCatch(e)}
}

// 功能描述:从a - b生成一个数组并返回
// 这以后将放入Jcore.js里
// 返回信息:返回取到的数组
// 使用指南:var a = [];a.ccp([23,234,"234"]).ccp([213123], "12313");
// 应用范围:各种Web客户端和服务端开发
Array.prototype.aList = function(a, b)
{
do{
this.push(a++)
}while(a < b);
return this;
}

// 功能描述:运行两段测试代码的方法
// 本方法将加入Jdebug.js,因此后面的章节不会出现这段代码了,请读者注意
// 返回信息:无返回
// 使用指南:系统用
function myTestRun(n, nRtCnt)
{
try{
var fnCode1 = fnMyTest._fnCode1, fnCode2 = fnMyTest._fnCode2;
// fnGetObjs将在第8章讲解,这里也先提到Jcore.js里
var cd1rt = fnGetObjs('cd1rt' + n)[0], cd2rt = fnGetObjs('cd2rt' + n)[0];
var i = 0, nStart = new Date().getTime();
do
{
fnCode1();
}while(++i < nRtCnt);
cd1rt.innerText =new Date().getTime() - nStart;
i = 0, nStart = new Date().getTime();
do
{
fnCode2();
}while(++i < nRtCnt);
cd2rt.innerText = new Date().getTime() - nStart;
fnMyTest.ovcnt++;
if(10 == fnMyTest.ovcnt)fnMyTest.free();
Msg(n + "号线程运行完毕");
}catch(e){fnCatch(e)}
}

// 功能描述:释放资源
// 本方法将加入Jdebug.js,因此后面的章节不会出现这段代码了,请读者注意
// 返回信息:无返回
// 使用指南:系统用
fnMyTest.free = function()
{
try{
delete fnMyTest._fnCode1;
delete fnMyTest._fnCode2;
fnMyTest.ovcnt = null;
Msg("资源已经释放");
}catch(e){}
}

// 功能描述:根据一个名称或id返回一个对象数组,
// 第8章讲解内容,这里先提到Jcore里去
// 返回信息:返回取到的数组
// 使用指南:fnGetObjs('myid')
// fnGetObjs('myInputName'),fnGetObjs('dto(aac009)')
// fnGetObjs('input');// 返回所有的input对象
// 应用范围:各种Web客户端和服务端开发
var fnGetObjs = Object.prototype.fnGetObjs = function(s)
{
// 支持从外面指定当前的window对象,往往我们需要在弹出窗口中获取父窗口
// 里的对象
var oWin = this.win || window, o = this.obj || oWin.document, oRst = [], oBjs;
oBjs = oWin.document.getElementsByName(s);
if(0 < oBjs.length)
return _A(oBjs).each(function()
{
// 如果不支持包含的判断或者已经包含
if(!o.contains || o.contains(this))
oRst.push(this)
}), oRst;
oBjs = oWin.document.getElementById(s);
if(!oBjs)
{
// 如果有o.getElementsByTagName为真才执行后面的表达式,
// 并返回其结果
return o.getElementsByTagName && _A(o.getElementsByTagName(s)).
each(function()
{
if(!o['contains'] || o['contains'](this))oRst.push(this)
}), oRst;
return [];
}
return [oBjs];
};

// 测试调用的代码
function fnTestMyCode()
{
try{
new fnMyTest(function()
{
// 普通的方式
var oMyObject = new Object();
oMyObject.name = "风云际会";
oMyObject.age = "天荒地老";
oMyObject.display = function()
{
alert([this.name, this.age].join("\n"));
};
}, function()
{
// 相同功能,性能更卓越的方式
// 注意:这里不能用等号,否则就发生错误
var oMyObject = {
// 注意:这里不能用等号,否则就发生错误,只能用冒号
name: "风云际会"
,age : "天荒地老"
,display:function()
{
alert([this.name, this.age].join("\n"));
}
};
}, 10000, "可以看出来,直接初始化的性能远远高于定义后在初始化的方式");
}catch(e){fnCatch(e)}
}
-->
</script>
<center><input type="button" value="运行" onclick="fnTestMyCode()"><br><br>
<table border="1" style="width:100%;">
<tr>
<th rowspan="2" width="120">运行次数及毫秒[每次运行<b id="tms"></b>回]</th>
<th>一般代码写法</th>
<th>优化代码写法</th>
</tr>
<tr>
<td id="code1">&nbsp;</td>
<td id="code2">&nbsp;</td>
</tr>
<tr>
<td>1</td>
<td id="cd1rt1" nowrap>&nbsp;</td>
<td id="cd2rt1" nowrap>&nbsp;</td>
</tr>
<tr>
<td>2</td>
<td id="cd1rt2" nowrap>&nbsp;</td>
<td id="cd2rt2" nowrap>&nbsp;</td>
</tr>
<tr>
<td>3</td>
<td id="cd1rt3" nowrap>&nbsp;</td>
<td id="cd2rt3" nowrap>&nbsp;</td>
</tr>
<tr>
<td>4</td>
<td id="cd1rt4" nowrap>&nbsp;</td>
<td id="cd2rt4" nowrap>&nbsp;</td>
</tr>
<tr>
<td>5</td>
<td id="cd1rt5" nowrap>&nbsp;</td>
<td id="cd2rt5" nowrap>&nbsp;</td>
</tr>
<tr>
<td>6</td>
<td id="cd1rt6" nowrap>&nbsp;</td>
<td id="cd2rt6" nowrap>&nbsp;</td>
</tr>
<tr>
<td>7</td>
<td id="cd1rt7" nowrap>&nbsp;</td>
<td id="cd2rt7" nowrap>&nbsp;</td>
</tr>
<tr>
<td>8</td>
<td id="cd1rt8" nowrap>&nbsp;</td>
<td id="cd2rt8" nowrap>&nbsp;</td>
</tr>
<tr>
<td>9</td>
<td id="cd1rt9" nowrap>&nbsp;</td>
<td id="cd2rt9" nowrap>&nbsp;</td>
</tr>
<tr>
<td>10</td>
<td id="cd1rt10" nowrap>&nbsp;</td>
<td id="cd2rt10" nowrap>&nbsp;</td>
</tr>
</table></center>
</body>
</html>


运行结果如图3-1所示。

图3-1  Object初始化的性能比较
想必,读者朋友已经知道将来设计代码的时候选择哪种方式初始化你的Object了。——事实是最好的证明。
【责任编辑:雪花 TEL:(010)68476606】

回书目   上一节   下一节
专题
主流防火墙性能对比分析
专题:网络性能测试
数据库之调试与性能优化
CCNA ICND 2认证考试指南
CCENT/CCNA ICND 1认证考试指南
我也说两句

匿名发表

(如果看不清请点击图片进行更换)


中 国 最 大 的 网 络 技 术 网 站 ·
技 术 成 就 梦 想
订阅技术快讯
电子杂志下载
名称:SQL Server数据库管理精品黄皮书
简介:书中文章经过精挑细选,便于用户能根据自己的实际工作和学习,快速在本书寻找到相关资料。内容涵盖了SQL Server的安装与升级、语句查询、数据备份和恢复、自动化任务、数据同步、数据字典、安全和预防、性能和优化、集群等各方面应用信息,以及DBA管理人员在数据库管理工作中
名称:2007路由技术大全
简介:《2007路由技术大全》由51CTO.com网站特别策划制作,该书包括路由器技术、路由器产品、路由器配置、安全设置、路由器故障处理、路由器密码恢复,以及广大网友在实践使用中的心得经验和技巧文章,内容注重实用性,适用于初学者入门,也适合多年从业者提高,是一本实践和理论完
名称:网络安全精品应用黄皮书
简介:《2007精品网络安全黄皮书》包括了9个大类24个小类, 800余篇文章,内容包含了熊猫烧香病毒、DDOS攻击、ARP病等热点问题的介绍及解决方案。从病毒查杀、防范、系统、数据等各方面的安全设置到黑客技术的了解、防范,涉及到了安全应用的全部领域, 由浅至深内容全面。
微软出价446亿美元收购雅虎
微软出价446亿美元收购雅虎
国际文档格式标准开战
国际文档格式标准开战
隐私保护技术探讨
隐私保护技术探讨
· 隐私保护技术探讨
· 华为员工自杀频频拷问..
· Windows Server 2008专..
· NAC安全访问控制
· PHP开发应用手册
· 技术人求职简历完备手册
· 北漂技术人90天求职纪实
· 勇闯IT培训黑色围城
· ASP.NET 2.0基础开发指..
· WCF开发基础
· 路由器设置与口令恢复
· VC++基础开发专题
· 2008年春季英特尔信息..
· Visual Studio 2005开..
· Linux——从菜鸟到高手
· 如何优化IT 控制能耗
清除流氓软件——51CTO特别专题
清除流氓软件——51CTO特别专..
ARP攻击防范与解决方案
ARP攻击防范与解决方案
iSCSI应用与发展
iSCSI应用与发展
· iSCSI应用与发展
· SQL Server 2008/2005..
· SOA 面向服务架构
· SQL Server 2008/2005..
· iSCSI应用与发展
· RAID——磁盘阵列基础
· 中间件应用技术专题
· SQL Server入门到精通
· 病毒查杀专题
· 国际文档格式标准开战
· Linux防火墙
· 路由器设置与口令恢复
· 打造安全服务器
· SOA 面向服务架构
· PHP开发应用手册
· ADSL应用面面俱到
ARP攻击防范与解决方案
ARP攻击防范与解决方案
SQL Server 2008/2005全解
SQL Server 2008/2005全解
iSCSI应用与发展
iSCSI应用与发展
· iSCSI应用与发展
· 中间件应用技术专题
· SQL Server入门到精通
· SQL Server 2008/2005..
· SOA 面向服务架构
· iSCSI应用与发展
· RAID——磁盘阵列基础
· 身份认证技术
· 病毒查杀专题
· 清除流氓软件——51CTO..
· 路由器设置与口令恢复
· SOA 面向服务架构
· 了解统一威胁管理(UTM)..
· ADSL应用面面俱到
· ADSL应用面面俱到
· 反垃圾邮件技术应用