Kotlin 基礎(chǔ)教程之異常
Kotlin 基礎(chǔ)教程之異常
概述
在Kotlin-null的處理里提到的NPE,它就是一個(gè)異常。而,異常是程序運(yùn)行過程中出現(xiàn)的錯誤。在Kotlin中,所有的異常都繼承于Throwable。對于每一個(gè)異常而言,它不僅僅包括異常的信息,還可以選擇性包括異常的原因,而其原因也是一個(gè)異常的實(shí)例。
拋出異常
使用 throw表達(dá)式拋出異常:
throw MyException("Hi There!")
捕獲異常
如果在函數(shù)內(nèi)部拋出了異常(或者在函數(shù)內(nèi)部調(diào)用的其他函數(shù)拋出了異常),這個(gè)函數(shù)將在拋出異常的地方結(jié)束。如果不希望函數(shù)結(jié)束,此時(shí)就必須捕獲這個(gè)被拋出的異常并處理這個(gè)異常。
在Kotlin中,要捕獲異常, 可以使用 try 表達(dá)式:
try { // 某些代碼 } catch (e: SomeException) { // 異常處理 } finally { // 可選的 finally 代碼段 }
- try語句塊:表示要嘗試運(yùn)行代碼,try語句塊中代碼受異常監(jiān)控,其中代碼發(fā)生異常時(shí),會拋出異常對象。
- catch語句塊:會捕獲try代碼塊中發(fā)生的異常并在其代碼塊中做異常處理,catch語句帶一個(gè)Throwable類型的參數(shù),表示可捕獲異常類型。當(dāng)try中出現(xiàn)異常時(shí),catch會捕獲到發(fā)生的異常,并和自己的異常類型匹配, 若匹配,則執(zhí)行catch塊中代碼,并將catch塊參數(shù)指向所拋的異常對象。catch語句可以有多個(gè), 用來匹配多個(gè)中的一個(gè)異常,一旦匹上配后,就不再嘗試匹配別的catch塊了。 通過異常對象可以獲取異常發(fā)生時(shí)完整的JVM堆棧信息,以及異常信息和異常發(fā)生的原因等。
- finally語句塊:緊跟catch語句后的語句塊,這個(gè)語句塊總是會在方法返回前執(zhí)行,而不管是否try語句塊是否發(fā)生異常。并且這個(gè)語句塊總是在方法返回前執(zhí)行。 目的是給程序一個(gè)補(bǔ)救的機(jī)會。這樣做也體現(xiàn)了Java語言的健壯性。
注:
- try、catch、finally三個(gè)語句塊均不能單獨(dú)使用,三者可以組成 try…catch…finally、try…catch、try…finally三種結(jié)構(gòu),catch語句可以有一個(gè)或多個(gè),finally語句最多一個(gè)。
- try、catch、finally三個(gè)代碼塊中變量的作用域?yàn)榇a塊內(nèi)部,分別獨(dú)立而不能相互訪問。如果要在三個(gè)塊中都可以訪問,則需要將變量定義到這些塊的外面。
- 多個(gè)catch塊時(shí)候,只會匹配其中一個(gè)異常類并執(zhí)行catch塊代碼,而不會再執(zhí)行別的catch塊,并且匹配catch語句的順序是由上到下。
- try表達(dá)式中可以有0個(gè)或多個(gè)catch代碼段. finally 代碼段可以省略. 但是,catch或 finally代碼段至少要出現(xiàn)一個(gè)與try配對出現(xiàn)。
自定義異常
在Kotlin標(biāo)準(zhǔn)庫中封裝的異常類型,不可能會預(yù)見所有的可能碰見的異常情況,此時(shí)自己定義異常,來表示程序中可能出現(xiàn)的特定問題。
如果想自定義異常,就必須繼承現(xiàn)有的異常類,一般都繼承其異常情況相似的類,建立異常類型最簡單的方法就是使用編輯器產(chǎn)生默認(rèn)的構(gòu)造方法,這樣簡單而有效。
fun main(args: Array<String>) { var b: String? = null try { b?.length ?: throw MyExcepttion("b不能為空") } catch (ex: MyExcepttion) { println("ex: ${ex.message}") } catch (npe: NullPointerException) { println("npe: ${npe.message}") } finally { println("finally") } } public class MyExcepttion(override val message: String) : Throwable(){ } // Log ex: b不能為空 finally
try表達(dá)式
在Kotlin中try是一個(gè)表達(dá)式, 也就是說, 它可以有返回值.
val a: Int? = try { parseInt(input) } catch (e: NumberFormatException) { null }
try表達(dá)式的返回值, 要么是try代碼段內(nèi)最后一個(gè)表達(dá)式的值,要么是 catch代碼段內(nèi)最后一個(gè)表達(dá)式的值. finally代碼段的內(nèi)容不會影響 try 表達(dá)式的結(jié)果值.
感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!
相關(guān)文章
Spring?Boot項(xiàng)目抵御XSS攻擊實(shí)戰(zhàn)過程
XSS攻擊又稱跨站腳本攻擊,通常指利用網(wǎng)頁開發(fā)時(shí)留下的漏洞,通過巧妙的方法注入惡意指令代碼到網(wǎng)頁,使用戶加載并執(zhí)行攻擊者惡意制造的網(wǎng)頁程序,下面這篇文章主要給大家介紹了關(guān)于Spring?Boot項(xiàng)目抵御XSS攻擊的相關(guān)資料,需要的朋友可以參考下2022-11-11java使用RSA加密方式實(shí)現(xiàn)數(shù)據(jù)加密解密的代碼
這篇文章給大家分享java使用RSA加密方式實(shí)現(xiàn)數(shù)據(jù)加密解密,通過實(shí)例代碼文字相結(jié)合給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友參考下2019-11-11Java Stream中的Spliterator類概念及原理解析
Spliterator是Java 8引入的一個(gè)接口,位于java.util包中,它結(jié)合了迭代器(Iterator)的遍歷能力和分割器(Splitter)的分割能力,本文將詳細(xì)介紹Spliterator的概念、原理、作用、類中定義的關(guān)鍵方法,以及它在Stream API中的實(shí)際應(yīng)用,感興趣的朋友一起看看吧2024-08-08Java獲取Process子進(jìn)程進(jìn)程ID方法詳解
這篇文章主要介紹了Java獲取Process子進(jìn)程進(jìn)程ID方法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)吧2022-12-12SpringBoot整合Mybatis的知識點(diǎn)匯總
在本篇文章里小編給各位整理的是關(guān)于SpringBoot整合Mybatis的知識點(diǎn)匯總,有興趣學(xué)習(xí)的參考下。2020-02-02