【你不知道的JS】-- 理解 try...catch...finally 语句

【你不知道的JS】-- 理解 try...catch...finally 语句

finally 中的代码总是会在 try 之后执行,如果有 catch 的话则在 catch 之后执行。也可以将 finally 中的代码看作一个回调函数,即无论出现仕么情况最后定会被调用。

  1. try 代码块中没有 return 和 throw 语句时
    try 代码块中没有 return 和 throw 语句时,会首先执行 try 中的语句,如果在执行时抛出了错误就会被 catch 捕获并执行 catch 中的代码,最终执行 finally 中的代码。
  2. try 代码块中有 return 或 throw 语句时
function foo() {
	try {
		return 42;
	}
	finally {
		console.log( "Hello" );
	}
	console.log( "never runs" );
}
console.log( foo() ); 
// Hello 
// 42

这里return 42先执行,并将foo()函数的返回值设置为42。然后try执行完毕,接着执行finally。最后foo()函数执行完毕,console.log(..)显示返回值。

try 中的 throw 也是如此

function foo() {
	try {
		throw 42;
	}
	finally {
		console.log( "Hello" );
	}
	console.log( "never runs" );
}
console.log( foo() ); 
// Hello 
// Uncatch Exception: 42
  1. 如果 finally 中抛出异常( 无论有意还是无意),函数就会在此处终止。如果此前 try 中已经有 return 设置了返回值,则该值会被丢弃。
function foo() {
	try {
		return 42;
	}
	finally {
		throw "Oops!";
	}
	console.log( "never runs" );
}
console.log( foo() ); 
// Uncatch Exception: 0ops !

continue 和 break 等控制语句也是如此:

for (var i=0; i<10; i++) {
	try {
		continue;
	}
	finally {
		console.log(i);
	}
}
// 0 1 2 3 4 5 6 7 8 9

continue在每次循环之后,会在i++执行之前执行console.log(i),所以结果是 0…9 而非 1…10。

  1. finally 中的 return 会覆盖 try 和 catch 中 return 的返回值。
function foo() {
	try {
		return 42;
	}
	finally {
		// 没有返回语句,所以没有覆盖
	}
}
function bar() {
	try {
		return 42;
	}
	finally {
		// 覆盖前面的 return 42
		return;
	}
}
function baz() {
	try {
		return 42;
	}
	finally {
		// 覆盖前面的 return 42
		return "Hello";
	}
}
foo(); // 42
bar(); // undefined
baz(); // Hello
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值