Exception

目的

l           當發生錯誤或執行到一個throw statement,馬上停止正常的程式執行,去尋找適當的exception handler來處理throw statement所丟出的意外狀況。

分類

l           可以用在throw statement的:ErrorThrowableExceptionRuntimeException

l           所有的exception都是java.lang.Throwablesubclasses,可分為三大類:

名稱(with subclasses)

catch

發生原因

java.lang.Error

no

嚴重的狀況如out of memory幾乎不可能收拾。程式中可以catch這類的exceptions,但catch到後也不能做任何補救,所以很少人會去catch這類的exception

java.lang.RuntimeExeption

no

program bug,如int i = 3/0;會發生java.lang.ArithmeticException

java.lang.Exeption(java.lang.
RuntimeExeption
除外)

yes

環境問題,如程式要讀取某網頁但該網站當機等。無法防止這類狀況發生,只能catch這個exception

處理方式

l           catchexception處理方式:

handling

使用try-catch-finally statement自己處理。

declaring

使用throws子句,宣告自己可能會丟出某些exception,而將exceptions丟給caller處理。Caller自己就不須用try-catch-finally block來處理。

l           exception發生時處理方式:

找到適當catch block

執行catch block,再執行finally block,然後程式執行恢復正常。(即執行finally block之後的statement)

未找到適當catch block

執行finally block,再將控制權交給外層的try/catch/finally statement。若所有外層都未catch住這個exception,程式異常終止。

執行順序

l           try / catch / finally順序不可顛倒。try之後可以只跟catch或只跟finally,但不可無catch也無finally

l           catch block的順序規則:

n           particular exception block須定義在前,general exception須定義在後。(catchException在前,Throwable在後)

n           若前面已catchclassexception object,後面的catch block不可再宣告catchclass或該classsubclass

注意

l           定義在finally block中的程式一定(must)會被執行,即使exception發生但沒有catch block或是trycatchblock中寫return,還是會被執行,除非在trycatchblock中執行到System.exit()或是在finally block中發生了exception

l           finally block的動作會蓋過前面trycatch block的動作。即finally blockreturnthrow statement會蓋掉trycatch blockreturnthrow statement

l           一個overriding method所丟出的exceptions不能超過overridden method所丟出的exceptions範圍,否則會發生compiler error(即子類別的exception可以與父類別exception相同或為該exceptionsubclass,但不可大於父類別的exception)

在Oracle数据库中,PL/SQL提供了强大的异常处理机制,用于捕获和处理运行时错误,使代码更健壮,能优雅处理意外情况,提高应用程序可靠性和用户体验 [^1]。 ### 异常处理方法 PL/SQL异常处理的基本结构包含三个部分:执行部分(BEGIN - END之间的代码)、异常处理部分(EXCEPTION块)和可选的声明部分(DECLARE块)。当执行部分的代码出现异常时,控制权会转移到异常处理部分。示例代码如下: ```plsql DECLARE -- 声明部分,可声明变量等 v_num NUMBER; BEGIN -- 执行部分 SELECT column_name INTO v_num FROM table_name WHERE condition; EXCEPTION -- 异常处理部分 WHEN NO_DATA_FOUND THEN DBMS_OUTPUT.PUT_LINE('未找到数据'); WHEN TOO_MANY_ROWS THEN DBMS_OUTPUT.PUT_LINE('返回了多行数据'); WHEN OTHERS THEN DBMS_OUTPUT.PUT_LINE('发生其他异常:' || SQLERRM); END; ``` 在这个例子中,`NO_DATA_FOUND`、`TOO_MANY_ROWS` 是预定义异常,`OTHERS` 用于捕获其他未明确指定的异常,`SQLERRM` 函数用于获取异常的错误信息。 ### 异常类型 - **预定义异常**:Oracle预定义了一些常见的异常,如 `NO_DATA_FOUND`(SELECT INTO语句未返回任何行)、`TOO_MANY_ROWS`(SELECT INTO语句返回多行)、`ZERO_DIVIDE`(除数为零)等。 - **非预定义异常**:对于一些没有预定义名称的Oracle错误,需要开发者自己将错误号与异常名称关联起来。示例如下: ```plsql DECLARE e_unique_violation EXCEPTION; PRAGMA EXCEPTION_INIT(e_unique_violation, -00001); -- -00001是唯一约束违反的错误号 BEGIN INSERT INTO table_name (column1, column2) VALUES (value1, value2); EXCEPTION WHEN e_unique_violation THEN DBMS_OUTPUT.PUT_LINE('违反唯一约束'); END; ``` - **自定义异常**:开发者可以根据业务需求自定义异常。示例如下: ```plsql DECLARE e_custom_exception EXCEPTION; v_age NUMBER := 15; BEGIN IF v_age < 18 THEN RAISE e_custom_exception; END IF; EXCEPTION WHEN e_custom_exception THEN DBMS_OUTPUT.PUT_LINE('年龄未满18岁'); END; ``` ### 异常传播 异常在嵌套块中会进行传播。当一个内部块中出现异常且该块没有对应的异常处理时,异常会传播到外部块进行处理。例如: ```plsql BEGIN BEGIN SELECT column_name INTO v_variable FROM table_name WHERE condition; EXCEPTION WHEN NO_DATA_FOUND THEN -- 内部块处理部分异常 DBMS_OUTPUT.PUT_LINE('内部块未找到数据'); END; EXCEPTION WHEN TOO_MANY_ROWS THEN -- 外部块处理其他异常 DBMS_OUTPUT.PUT_LINE('外部块返回多行数据'); END; ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值