溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

Swift?Error的處理方法是什么

發(fā)布時(shí)間:2022-08-24 10:29:17 來(lái)源:億速云 閱讀:118 作者:iii 欄目:開(kāi)發(fā)技術(shù)

這篇文章主要講解了“Swift Error的處理方法是什么”,文中的講解內(nèi)容簡(jiǎn)單清晰,易于學(xué)習(xí)與理解,下面請(qǐng)大家跟著小編的思路慢慢深入,一起來(lái)研究和學(xué)習(xí)“Swift Error的處理方法是什么”吧!

錯(cuò)誤類型

1、開(kāi)發(fā)過(guò)程常見(jiàn)的錯(cuò)誤

  • 語(yǔ)法錯(cuò)誤(編譯報(bào)錯(cuò))

  • 邏輯錯(cuò)誤

  • 運(yùn)行時(shí)錯(cuò)誤(可能會(huì)導(dǎo)致閃退,一般也叫做異常),也是我們今天講的重點(diǎn)

自定義錯(cuò)誤

1、Swift中可以通過(guò)Error協(xié)議自定義運(yùn)行時(shí)的錯(cuò)誤信息

enum SomeError: Error {
    case illegalArg(String)
    case outOfBounds(Int, Int)
    case outOfMemory
}

2、函數(shù)內(nèi)部通過(guò)throw拋出自定義Error,可能會(huì)拋出Error的函數(shù)必須加上throws聲明

func divide(_ num1: Int, _ num2: Int) throws -> Int {
    if num2 == 0 {
        throw SomeError.illegalArg("0不能作為除數(shù)")
    }
    return num1 / num2
}

3、需要使用try調(diào)用可能會(huì)拋出Error的函數(shù)

4、可以使用do-catch捕捉Error

func test() {
    do {
        try divide(20, 0)
    } catch let SomeError.illegalArg(msg) {
        print("參數(shù)異常:", msg)
    } catch let SomeError.outOfBounds(size, index) {
        print("下標(biāo)越界:", "size = \(size), index = \(index)")
    } catch SomeError.outOfMemory {
        print("內(nèi)存溢出")
    } catch {
        print("其他錯(cuò)誤")
    }
}

5、拋出Error后,try下一句直到作用域結(jié)束的代碼都停止運(yùn)行

處理Error

1、處理Error的2種方式

a、通過(guò)do-catch捕捉Error

b、不捕捉Error,在當(dāng)前函數(shù)增加throws聲明,Error將自動(dòng)拋給上層函數(shù)

func test() throws {
    print(try divide(200, 0))
}

如果最頂層函數(shù)(main函數(shù))依然沒(méi)有捕捉Error,那么程序?qū)⒔K止

以下是幾種error的處理方法:

func test() throws {
    do {
        print(try divide(200, 0))
    } catch let error as SomeError {
        print(error)
    }
}
func test() throws {
    do {
        print(try divide(200, 0))
    } catch is SomeError {
        print("SomeError")
    }
}
do {
    try divide(20, 0)
} catch let error {
    switch error {
    case let SomeError.illegalArg(msg):
        print("參數(shù)異常:", msg)
    default:
        print("其他異常")
    }
}

我們通過(guò)一個(gè)例子來(lái)總結(jié)一下處理Error的2種方式:

override func viewWillAppear(_ animated: Bool) {
    super.viewWillAppear(animated)
    try test0()
}
func test0() throws -> Void {
    try test1()
}
func test1() throws -> Void {
    try test2()
}
func test2() throws -> Void {
    do {
        print(try divide(200, 0))
    } catch is SomeError {
        print("This is SomeError")
    }
}

try?與try!

1、可以使用try?、try!調(diào)用可能會(huì)拋出Error的函數(shù),這樣就不用去處理Error

func test() -> Void {
    print("1")
    var result1 = try? divide(20, 10) // Optional(2), Int?
    var result2 = try? divide(20, 0) // nil
    var result3 = try! divide(20, 10) // 2, Int
    print("2")
}

2、a、b是等價(jià)的

var a = try? divide(20, 0)
var b: Int?
do {
    b = try divide(20, 0)
} catch {
    b = nil
}

rethrows

1、rethrows表明:函數(shù)本身不會(huì)拋出錯(cuò)誤,但調(diào)用閉包參數(shù)拋出錯(cuò)誤,那么它會(huì)將錯(cuò)誤向上拋

func exec(_ fn: (Int, Int) throws -> Int, _ num1: Int, _ num2: Int) rethrows -> Void {
    print(try fn(num1, num2))
}

defer

1、defer語(yǔ)句:用來(lái)定義以任何方式(拋錯(cuò)誤、return等)離開(kāi)代碼塊前必須要執(zhí)行的代碼

defer語(yǔ)句將延遲到當(dāng)前作用域結(jié)束之前執(zhí)行

func open(_ filename: String) -> Int {
    print("open")
    return 1
}
func close(_ file: Int) -> Void {
    print("close")
}
func processFile(_ filename: String) throws -> Void {
    let file = open(filename)
    defer {
        close(file)
    }
    try divide(20, 0)
}

2、defer語(yǔ)句的執(zhí)行順序與定義順序相反

func fn1() -> Void {
    print("fn1")
}
func fn2() -> Void {
    print("fn2")
}
func testDefer() -> Void {
    defer {
        fn1()
    }
    defer {
        fn2()
    }
} //fn2 fn1

感謝各位的閱讀,以上就是“Swift Error的處理方法是什么”的內(nèi)容了,經(jīng)過(guò)本文的學(xué)習(xí)后,相信大家對(duì)Swift Error的處理方法是什么這一問(wèn)題有了更深刻的體會(huì),具體使用情況還需要大家實(shí)踐驗(yàn)證。這里是億速云,小編將為大家推送更多相關(guān)知識(shí)點(diǎn)的文章,歡迎關(guān)注!

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI