您好,登錄后才能下訂單哦!
這篇文章主要講解了“Swift Error的處理方法是什么”,文中的講解內(nèi)容簡(jiǎn)單清晰,易于學(xué)習(xí)與理解,下面請(qǐng)大家跟著小編的思路慢慢深入,一起來(lái)研究和學(xué)習(xí)“Swift Error的處理方法是什么”吧!
1、開(kāi)發(fā)過(guò)程常見(jiàn)的錯(cuò)誤
語(yǔ)法錯(cuò)誤(編譯報(bào)錯(cuò))
邏輯錯(cuò)誤
運(yùn)行時(shí)錯(cuò)誤(可能會(huì)導(dǎo)致閃退,一般也叫做異常),也是我們今天講的重點(diǎn)
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)行
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") } }
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 }
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)) }
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)注!
免責(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)容。