https://blog.csdn.net/shmnh/article/details/52445186

起因

要捕获 JavaScript 代码中的异常一般会采用 try catch,不过 try catch 的使用是否是对代码性能产生影响呢?答案是肯定有的,但是有多少不得而知。

淘宝前端线上脚本错误的捕获方法:

 
window.JSTracker = window.JSTracker || [];
try{
//your code
}catch(e){
JSTracker.push(e);
throw e; //建议将错误再次抛出,避免测试无法发现异常
}

设计实验方式

简单的设计方案也就是对比实验。

空白组1:[无 try catch 的情况下对数据取模1千万次耗时]

 
 <!DOCTYPE html>
<html>
<head>
<title>1 无try catch的情况耗时</title>
<script>
!function() {
//无try catch的情况耗时
var t = new Date(); //耗时代码开始
for (var i = 0; i < 100000000; i++) {
var p = i % 2;
}
//耗时代码结束
document.write(new Date() - t);
}();
</script>
</head>
<body> </body>
</html>

参照组2:[将耗时代码用 try 包围,内联耗时代码]

 
<!DOCTYPE html>
<html>
<head>
<title>2 在 try 中内联代码的耗时情况</title>
<script>
!function() { //在 try 中内联代码的耗时情况
var t = new Date();
try{
//耗时代码开始
for (var i = 0; i < 100000000; i++) {
var p = i % 2;
}
//耗时代码结束
throw new Error();
}catch(e){ }
document.write(new Date() - t);
}();
</script>
</head>
<body> </body>
</html>

参照组3:[将耗时代码用 try 包围,外联耗时代码]

 
<!DOCTYPE html>
<html>
<head>
<title>3 在 try 中内联代码的耗时情况</title>
<script>
!function() {
function run(){
//耗时代码开始
for (var i = 0; i < 100000000; i++) {
var p = i % 2;
}
//耗时代码结束
}
//在 try 中内联代码的耗时情况
var t = new Date();
try{
run();
throw new Error();
}catch(e){ }
document.write(new Date() - t);
}();
</script>
</head>
<body> </body>
</html>

参照组4:[将耗时代码用 catch 包围,内联耗时代码]

 
<!DOCTYPE html>
<html>
<head>
<title>4 在 catch 中内联代码的耗时情况</title>
<script>
!function() { //在 catch 中内联代码的耗时情况
var t = new Date();
try{
throw new Error();
}catch(e){
//耗时代码开始
for (var i = 0; i < 100000000; i++) {
var p = i % 2;
}
//耗时代码结束 }
document.write(new Date() - t);
}();
</script>
</head>
<body> </body>
</html>

参照组5:[将耗时代码用 catch 包围,外联耗时代码]

 
<!DOCTYPE html>
<html>
<head>
<title>5 在 catch 中内联代码的耗时情况</title>
<script>
!function() {
function run(){
//耗时代码开始
for (var i = 0; i < 100000000; i++) {
var p = i % 2;
}
//耗时代码结束
}
//在 catch 中内联代码的耗时情况
var t = new Date();
try{
throw new Error();
}catch(e){
run();
}
document.write(new Date() - t);
}();
</script>
</head>
<body> </body>
</html>

运行结果(只选取了 Chrome 作为示例)

- 不使用 try-catch try 中耗时,内联代码 try 中耗时,外联代码 catch 中耗时,内联代码 catch 中耗时,外联代码
Chrome44 98.2 1026.9 107.7 1028.5 105.9

给出总结

  • 使用 try catch 的使用无论是在 try 中的代码还是在 catch 中的代码性能消耗都是一样的。
  • 需要注意的性能消耗在于 try catch 中不要直接塞进去太多的代码(声明太多的变量),最好是吧所有要执行的代码放在另一个 function 中,通过调用这个 function 来执行。

针对第二点,可以查看 ECMA 中关于 try catch 的解释,在代码进入 try catch 的时候 js引擎会拷贝当前的词法环境,拷贝的其实就是当前 scope 下的所有的变量。

建议

在使用 try catch 的时候尽量把 try catch 放在一个相对干净的 scope 中,同时在 try catch 语句中也尽量保证足够少的变量,最好通过函数调用方式来 try catch。

试验中的现象解释

测试过程中还是发现了一个疑问, 以下两段代码在 Chrome 44 中运行出来的结果差距非常大,加了一句空的 try catch 之后平均为:850ms,加上之前为:140ms。

 
!function() {
//无 try catch 的情况耗时
var t = new Date(); //耗时代码开始
for (var i = 0; i < 100000000; i++) {
var p = i % 2;
}
//耗时代码结束
document.write(new Date() - t);
try{
}catch(e){ }
}();
 
!function() {
//无 try catch 的情况耗时
var t = new Date(); //耗时代码开始
for (var i = 0; i < 100000000; i++) {
var p = i % 2;
}
//耗时代码结束
document.write(new Date() - t); }();

其实原因很简单
只要把代码改为这样 耗时就降下来了:

 
!function() {
!function() {
//无 try catch 的情况耗时
var t = new Date(); //耗时代码开始
for (var i = 0; i < 100000000; i++) {
var p = i % 2;
}
//耗时代码结束
document.write(new Date() - t);
}();
try{
}catch(e){ }
}();

js中(try catch) 对代码的性能影响的更多相关文章

  1. JS中try catch的用法

    在js中也可以使用try/catch语法,把可能发生异常的代码使用try包裹起来,然后在catch中对异常进行处理,处理后就不会影响后面代码的执行. const a = null try { cons ...

  2. 如何在 JS 中嵌入大量 HTML 代码 --更新2017-10-10 16:37:09

    一.一般方式 方式1:\ 要写在标签后面,看例子 var longString = "\ ------------------------\ ------------------------ ...

  3. JS中 try...catch...finally (转)

    JS的try..catch..finally var array = null; try { document.write(array[0]); } catch(err) { document.wri ...

  4. JS中的常用的代码操作

    本文件介绍常用的js代码的DOM操作.CSS操作.对象(Object对象.Array对象.Number对象.String对象.Math对象.JSON对象和Console对象)操作说明. 一.DOM树的 ...

  5. JS中try....catch

    1.事情还有得挽回,换条路走try { 执行某个逻辑} catch (e) { 出问题,换个逻辑执行} 2.体面的退出try { 正常流程} catch (e) { 弹个框告诉用户不好意思出了点问题 ...

  6. js中嵌入jsp(html)代码的双引号转换问题--事件没反应

    下面是一段今天遇到问题的代码,select中写了onchange事件 ,在没有加转义的情况下,F12解析的代码是错乱的,双引号与内容中写的不一致,还会有空格出现,经过一段时间的摸索,发现在出错的地方加 ...

  7. JS中try.. catch..的用法

    try 测试代码块的错误. catch 语句处理错误. throw 创建并跑出错误. try { //在这里运行代码 抛出错误 } catch(err) { //在这里处理错误 } 下面是一个实例: ...

  8. 使用java写js中类似setTimeout的代码

    javascript目前已经是一门相当主流的编程语言了,它的异步IO特定项目其他编程语言来说,大大减少了cpu在线程切换方面的速度.实现了单线程高并发的奇迹.而java作为老牌编程语言,在很多的项目中 ...

  9. Node.js中测试mysql的代码var client = mysql.createClient运行出错:TypeError: Object # has no method ‘createClient’

    今天在WebStorm下熟悉一个node.js的项目,配置环境时,手一抖,将mysql包从0.8升级到了2.1.1,结果再运行时就出错了. [Fri Mar 14 2014 17:05:49] 连接数 ...

随机推荐

  1. Ubuntu 系统搭建LNMP环境

    当前Linux版本:Ubuntu16.04 一.安装Nginx 在终端中输入命令 " sudo apt-get install nginx ",在确认安装完成后,在浏览器中访问 l ...

  2. Oracle Flashback Transaction Query with Oracle Flashback Version Query

    Oracle Flashback Transaction Query with Oracle Flashback Version Query In this example, a database a ...

  3. 十四、python字典中的方法汇总

    '''1.访问.修改,删除字典中的值:''' dict={'a':'11','b':'22','c':'33','d':'44'}print dict['a'],dict['d'] #访问dict[' ...

  4. iOS 命令行打包--xcworkspace

    参考: 打包的具体操作步骤: https://www.jianshu.com/p/6a0aa8cd2e97 打包时使用到的参数详解,参考这篇: https://debugtalk.com/post/i ...

  5. 阶段1 语言基础+高级_1-3-Java语言高级_02-继承与多态_第6节 权限修饰符_6_四种权限修饰符

    四种权限修饰符.从大到小 纵向再分成四种情况 同一个类 同一个类里面.private方式,可以访问到本类里面的 num成员变量 前面不写修饰符也能访问到 (default)就是不写的这种情况 受保护的 ...

  6. 测开之路一百:jquery引用、语法、事件

    工作中一般会使用jquery代替js,jquery官网:https://jquery.com/ 引用jquery: 第一种方式:下载引用: jquery下载官网:https://jquery.com/ ...

  7. TP框架对数据库的基本操作

    数据库的操作,无疑就是连接数据库,然后对数据库中的表进行各种查询,然后就是对数据的增删改的操作,一步步的讲述一下框架对数据库的操作 想要操作数据库,第一步必然是要:链接数据库 一.链接数据库 (1)找 ...

  8. 20191105 《Spring5高级编程》笔记-第9章

    第9章 事务管理 一些名词: 2PC(2 Phase Commit) XA协议 JTS(Java Transaction Service) JCA(Java EE Connector Architec ...

  9. Angular5 import interface 报错:XXX is not a module

    在项目里定义了一个interface,device.ts.然后在component.ts中要使用这个interface,import之后,VSCode报错:‘xxx/xxx/xxx/device.ts ...

  10. dfs(首尾字母)

    http://acm.hdu.edu.cn/showproblem.php?pid=1181 变形课 Time Limit: 2000/1000 MS (Java/Others)    Memory ...