try catch语句

try catch语句

try-catch 语句,作为 JavaScript 中处理异常的一种标准方式。基本的语法如下所示:

try{
// 可能会导致错误的代码
} catch(error){
// 在错误发生时怎么处理
}

如果 try 块中的任何代码发生了错误,就会立即退出代码执行过程,然后接着执行 catch 块。此时,catch 块会接收到一个包含错误信息的对象。即使你不想使用这个错误对象,也要给它起个名字。这个对象中包含一个保存着错误消息的 message 属性和一个保存错误类型的 name 属性。

finally 子句
虽然在 try-catch 语句中是可选的,但 finally 子句一经使用,其代码无论如何都会执行。换句话说,try 语句块中的代码全部正常执行,finally 子句会执行;如果因为出错而执行了 catch 语句块,finally 子句照样还会执行。只要代码中包含 finally 子句,则无论 try 或 catch 语句块中包含什么代码——甚至 return 语句,都不会阻止 finally 子句的执行。来看下面这个函数。

function testFinally(){
try {
return 2;
} catch (error){
return 1;
} finally {
return 0;
}
}

这个函数在 try-catch 语句的每一部分都放了一条 return 语句。表面上看,调用这个函数会返回 2,因为返回 2 的 return 语句位于 try 语句块中,而执行该语句又不会出错。可是,由于最后还有一个 finally 子句,结果就会导致该 return 语句被忽略;也就是说,调用这个函数只能返回 0。如果把 finally 子句拿掉,这个函数将返回 2。

只要代码中包含 finally 子句,那么无论try 还是catch 语句块中的return 语句都将被忽略。

如果提供 finally 子句,则 catch 子句就成了可选的(catch 或 finally 有一个即可)。

错误类型
执行代码期间可能会发生的错误有多种类型。每种错误都有对应的错误类型,而当错误发生时,就会抛出相应类型的错误对象。JS有下列 7 种错误类型:

Error
EvalError
RangeError
ReferenceError
SyntaxError
TypeError
URIError
其中,Error 是基类型,其他错误类型都继承自该类型。,所有错误类型共享了一组相同的属性(错误对象中的方法全是默认的对象方法)。Error 类型的错误很少见,如果有也是浏览器抛出的;这个基类型的主要目的是供开发人员抛出自定义错误。

EvalError 类型的错误会在使用 eval()函数而发生异常时被抛出。如果以非直接调用的方式使用 eval 属性的值,或者为 eval 属性赋值,简单地说,如果没有把 eval()当成函数调用,就会抛出错误,例如:

new eval(); //抛出 EvalError
eval = foo; //抛出 EvalError
1
2
在实践中,浏览器不一定会在应该抛出错误时就抛出 EvalError。例如,Firefox 4+和 IE8 对第一种情况会抛出 TypeError,而第二种情况会成功执行,不发生错误。

RangeError 类型的错误会在数值超出相应范围时触发。例如,在定义数组时,如果指定了数组不支持的项数(如-20 或 Number.MAX_VALUE),就会触发这种错误。

ReferenceError 类型的错误会在访问不存在的变量时发生。

SyntaxError 类型的错误会在我们把语法错误的 JavaScript 字符串传入 eval()函数时,就会导致此类错误。如果语法错误的代码出现在 eval()函数之外,则不太可能使用 SyntaxError,因为此时的语法错误会导致 JavaScript 代码立即停止执行。

TypeError 类型在 JavaScript 中会经常用到,在变量中保存着意外的类型时,或者在访问不存在的方法时,都会导致这种错误。错误的原因虽然多种多样,但归根结底还是由于在执行特定于类型的操作时,变量的类型并不符合要求所致。下面来看几个例子。

var o = new 10; //抛出 TypeError
alert(“name” in true); //抛出 TypeError
Function.prototype.toString.call(“name”); //抛出 TypeError

最常发生类型错误的情况,就是传递给函数的参数事先未经检查,结果传入类型与预期类型不相符。

URIError 类型的错误会在使用 encodeURI()或 decodeURI(),而 URI 格式不正确时,就会导致 URIError 错误。这种错误也很少见,因为前面说的这两个函数的容错性非常高。
————————————————
原文链接:https://blog.youkuaiyun.com/weixin_42561383/article/details/99687113

### Try-Catch 语句概述 Try-catch 是一种用于处理程序运行期间可能出现异常情况的机制。通过这种方式,可以确保即使遇到意外状况,应用程序仍能够优雅地继续执行或终止。 #### 基本结构 基本形式由 `try` 和至少一个 `catch` 组成: ```java try { // 可能引发异常的操作 } catch (ExceptionType exceptionVariable) { // 处理特定类型的异常逻辑 } ``` 此结构允许开发者指定哪些部分代码可能触发异常,并定义当这些异常确实发生时应采取什么行动[^2]。 #### 扩展结构——包含 Finally 块 为了进一步增强灵活性,在某些情况下还可以加入 `finally` 子句来保证无论是否发生了异常都会被执行的一段代码: ```java try { // 尝试执行可能会失败的任务 } catch (SpecificException se) { // 针对该种具体异常做出响应 } finally { // 不管怎样都要做的收尾工作 } ``` 这段附加的部分对于资源释放特别有用,比如关闭文件流或是网络连接等操作[^3]。 #### 支持捕获错误原因 更高级的应用场景下,可以通过扩展语法捕捉到具体的错误信息并作出相应反应: ```solidity // Solidity 示例 try externalContract.f() returns(uint result){ // 成功调用后的业务逻辑 } catch Error(string memory reason) { emit Log(reason); } ``` 这里展示了如何在一个智能合约环境中利用 try-catch 结构不仅管理常规流程中的潜在风险点,还能获取详细的报错描述以便调试分析[^4]。 #### C++ 中的通用异常处理器 值得注意的是,在不同编程语言里实现细节有所差异。例如,在 C++ 中有一种特殊的写法用来应对那些事先无法预料其确切类别的异常事件: ```cpp try { // 操作... } catch (...) { // 对于所有未被捕获的异常统一处理 } ``` 这种做法使得即便面对未曾预见的情况也能保持系统的稳定性,避免因突发问题而导致整个应用崩溃[^5]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值