try catch finally 子句是 ECMA2015 - try catch statment 中定义的语法。 其执行机制以下ui
try catch 语句首先会执行try包裹的代码块,根据代码块执行结果判断是否进入catch的代码块,若是catch的代码块有返回结果,则抛出异常时会覆盖try语句的执行结果。不然由于Block是异常抛出,返回undefined。lua
function test (){
try {
return 0
} catch (e) {
return 1
}
}
test() // 0
function test1 (){
try {
throw new Error()
return 0 // 这里不会执行到
} catch (e) {
return 1
}
}
test1() //1
复制代码
Block 和 finally包裹的代码会依次执行,同时记录其返回结果 B 与 F,若是F 有返回值(正常或者异常返回),则返回F的结果,不然返回B的结果spa
function test (){
try {
throw new Error()
} finally {
return 1
}
}
test() // 1
function test1 (){
try {
throw new Error()
} finally {
throw new Error();
}
}
test1() // Uncaught Error
function test2 (){
try {
return 0
} finally {
}
}
test2() // 0
function test3 (){
try {
return 0
} finally {
return 1
}
}
test3() // 1
复制代码
至关于 try catch 和try finally 的组合执行,先执行try catch 的处理结果 再将其结果与finally合并。code
function test() {
var a = 1;
try {
return a;
} finally {
++a;
}
}
test() // 1
function test1() {
var a = 1;
try {
return a;
} finally {
++a;
return a;
}
}
test1() // 2
function test2() {
var obj = {a:1};
try {
return obj;
} finally {
++obj.a;
}
}
test2().a // 2
function test3() {
var obj = {a:1};
try {
return obj.a;
} finally {
++obj.a;
}
}
test1() // 1
复制代码