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. centos 6.9 mysql 安装配置

    1.全新系统,安装mysql yum -y install mysql mysql-server mysql-devel 2.启动mysql service mysqld start 3.修改密码 登 ...

  2. xargs -i参数详解

    学习所需,文章转载过来! xargs与find经常结合来进行文件操作,平时删日志的时候只是习惯的去删除,比如 # find . -type f -name "*.log" | xa ...

  3. 记一次odoo创建新的模块时,但是在odoo web界面找不到应用的案例

    原因就是在odoo.conf配置文件中没有说明  模块查找的路径

  4. Django路由小知识

    from django.urls import path,re_path from app01 import views urlpatterns = [ re_path(r'^articles/200 ...

  5. Elastic Search笔记

    目录 1.简介 2.概念和工具使用 2.1 基本概念 2.2 使用kibana 3.操作索引和数据 2.3 索引 2.4 索引映射到文档 2.5 新增数据 2.6 修改数据 2.7 删除数据 4. 搜 ...

  6. 博客图片上传picgo工具安装配置github图传使用

    摘要 对于每一个写博客的人来说,图片是至关重要.这一路经历了多次图片的烦恼,之前选择了微博个人文章那里粘贴图片的方式上传,感觉也挺方便的.但是由于新浪的图片显示问题,如果header中不设置 标签就不 ...

  7. python--url编码/解码

    from urllib import parse 1.url编码:#定义一个url请求url='http://www.baidu.com?query=python基础教程' url_str = par ...

  8. myeclipse 2015 myeclipse2010破解共存

    1.高版本选择bling版本,低版本选择profession版本2.用高版本的公钥替换低版本的公钥3.先破解低版本的后破解高版本的4.最后用高版本的替换低版本的文件

  9. Vue组件父子间通信01

    子组件传递数据 用户已经登录 父组件接收数据 并显示列表,未登录不显示列表 /* 有两个组件,分别是main-component,header-component.main-component是由he ...

  10. (4.31)quotename函数

    操作sql server尤其是写存储过程时,要用到各种各样的函数,今天就总结一个quotename()的用法. 1.语法: quotename(‘character_string’[,‘quote_c ...