javascript中的异常处理

常见的异常分类

  • 运行环境的多样性导致的异常
  • 语法错误,代码错误
    异常的最大特征,就是一旦代码出现错误,后面的代码就不会再执行

异常捕获

捕获异常,使用try-catch语句

1
2
3
4
5
6
7
8
try{
// 这里写可能会出错的代码
}catch(e){
// e就是异常信息
// 出现异常后的处理代码
}finally {
// 不管是否异常,都会执行这里的代码
}

异常捕获语句执行的过程为:

  1. 如果在try中出现了错误, 直接跳转到 catch 中,catch中处理错误信息,然后执行finally中的代码

  2. 如果try中大代码没有出现异常, catch内部的代码就不会执行, 但是,finally中的代码还是会要执行

注意:

finally中的代码,不管有没有发生异常,都会执行。一般用在后端语言中,用来释放资源,JavaScript中很少会用到

通过try-catch语句进行异常捕获之后,代码将会继续执行,而不会中断。

注意:

  • 语法错误异常用try-catch语句无法捕获,因为在预解析阶段,语法错误会直接检测出来,而不会等到运行的时候才报错。
  • try-catch在一般日常开发中基本用不到,但是如果要写框架什么的,用的会非常多。因为这个会让框架变得健壮

抛出异常

如何手动的抛出异常呢?

案例:自己写的一个函数,需要一个参数,如果用户不传参数,此时想直接给用户抛出异常,就需要了解如何抛出异常。
抛出异常使用throw关键字,语法如下:

1
throw 异常对象;

异常对象一般是用new Error("异常消息"), 也可以使用任意对象

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
// 求两个数的和
function sum(a, b){
return (a+b)
}

// 此时如果程序员A调用的sum这个求和函数
sum('love', 'you') // 输出 "loveyou"
// 明显,是和sum这个函数的定义不相符,此时就可以使用throw来手动抛出异常

function sum(a, b){
if(typeof a == 'number' && typeof b == 'number'){
return a+b
}else{
// throw new Error("参数必须是数字");
// 这里也可以使用自定义的对象
throw {
errCode:0,
errMsg:"参数必须是数字"
};
}
}
try{
sum('love', 'you')
}catch(e){
console.log(e)
}

01.png

异常的传递机制

1
2
3
4
5
6
7
8
9
10
11
12
function f1 () {
f2(); // f1 称为调用者, 或主调函数, f2 称为被调用者, 或被调函数
}

function f2 () {
f3();
}

function f3() {
throw new Error( 'error' );
}
f1();

当在被调函数内发生异常的时候,异常会一级一级往上抛出。