Swift?Error的處理方法說明
錯(cuò)誤類型
1、開發(fā)過程常見的錯(cuò)誤
- 語法錯(cuò)誤(編譯報(bào)錯(cuò))
- 邏輯錯(cuò)誤
- 運(yùn)行時(shí)錯(cuò)誤(可能會(huì)導(dǎo)致閃退,一般也叫做異常),也是我們今天講的重點(diǎn)
自定義錯(cuò)誤
1、Swift中可以通過Error協(xié)議自定義運(yùn)行時(shí)的錯(cuò)誤信息
enum SomeError: Error {
case illegalArg(String)
case outOfBounds(Int, Int)
case outOfMemory
}2、函數(shù)內(nèi)部通過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、通過do-catch捕捉Error
b、不捕捉Error,在當(dāng)前函數(shù)增加throws聲明,Error將自動(dòng)拋給上層函數(shù)
func test() throws {
print(try divide(200, 0))
}如果最頂層函數(shù)(main函數(shù))依然沒有捕捉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("其他異常")
}
}我們通過一個(gè)例子來總結(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語句:用來定義以任何方式(拋錯(cuò)誤、return等)離開代碼塊前必須要執(zhí)行的代碼
defer語句將延遲到當(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語句的執(zhí)行順序與定義順序相反
func fn1() -> Void {
print("fn1")
}
func fn2() -> Void {
print("fn2")
}
func testDefer() -> Void {
defer {
fn1()
}
defer {
fn2()
}
} //fn2 fn1到此這篇關(guān)于Swift Error的處理方法說明的文章就介紹到這了,更多相關(guān)Swift Error內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
深入解析Swift中switch語句對(duì)case的數(shù)據(jù)類型匹配的支持
這篇文章主要介紹了Swift中switch語句對(duì)case的數(shù)據(jù)類型匹配的支持,Swift中switch...case語句支持多種數(shù)據(jù)類型的匹配判斷,十分強(qiáng)大,需要的朋友可以參考下2016-04-04
openstack重啟swift服務(wù)后報(bào)錯(cuò)問題解決方案
這篇文章主要介紹了解決openstack重啟swift服務(wù)后報(bào)錯(cuò),本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2023-08-08
SwiftUI?List在MacOS中的性能優(yōu)化示例
這篇文章主要為大家介紹了SwiftUI?List在MacOS中的性能優(yōu)化示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-09-09
在Swift中使用KVO的細(xì)節(jié)以及內(nèi)部實(shí)現(xiàn)解析(推薦)
這篇文章主要介紹了在Swift中使用KVO的細(xì)節(jié)以及內(nèi)部實(shí)現(xiàn)解析,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-07-07
Swift高階函數(shù)contains?allSatisfy?reversed?lexicographicallyPr
這篇文章主要為大家介紹了Swift高階函數(shù)contains?allSatisfy?reversed?lexicographicallyPrecedes用法示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-06-06

