- 錯(cuò)誤處理
- 泛型
- ErrorHandling
import UIKit
class ViewController: UIViewController {
// 使用Error協(xié)議類型來標(biāo)識(shí)錯(cuò)誤
private enum PrinterError: Error {
case outOfpaper
case noToner
case onFire
}
// 使用"throws"來制作一個(gè)可以拋出錯(cuò)誤的函數(shù)
private func send(job: String, toPrinter PrinterName: String) throws -> String {
if PrinterName == "never has onToner" {
throw PrinterError.outOfpaper // 使用"throw"來拋出一個(gè)錯(cuò)誤
}
return "\(job) Sent + \(PrinterName)"
}
/*
如果你在一個(gè)函數(shù)中拋出一個(gè)錯(cuò)誤,那么這個(gè)函數(shù)執(zhí)行到"throw"會(huì)立刻返回,調(diào)用這個(gè)函數(shù)的代碼進(jìn)行處理這個(gè)錯(cuò)誤.
*/
// 下面是一些處理錯(cuò)誤的方法:
override func viewDidLoad() {
super.viewDidLoad()
/*
一種方法是"do-catch", 在"do"代碼塊中,你可以使用"try"來標(biāo)記一個(gè)可以拋出錯(cuò)誤的代碼,
在"catch"代碼塊中恶耽,除非你給這個(gè)錯(cuò)誤一個(gè)不同的名字,否則它自動(dòng)命名為"error"
*/
// 輸出: printError:outOfpaper
do {
try send(job: "Hunter", toPrinter: "never has onToner")
} catch PrinterError.noToner {
print("I'll just put this over here, with the rest of the fire.")
} catch let printerError as PrinterError {
print("printError:\(printerError)")
} catch {
print(error)
}
/*
另一個(gè)處理錯(cuò)誤的方法是使用"try"其轉(zhuǎn)變的結(jié)果是一個(gè)可選值颜启。
如果函數(shù)會(huì)拋出一個(gè)錯(cuò)誤偷俭,這個(gè)錯(cuò)誤會(huì)被拋棄,結(jié)果會(huì)是"nil"
否則缰盏,結(jié)果會(huì)是這個(gè)函數(shù)返回的可選值.
*/
// 輸出: nil
print(try? send(job: "Hunter", toPrinter: "never has onToner"))
// 輸出: Optional("Hunter Sent + 啦啦啦??")
print(try? send(job: "Hunter", toPrinter: "啦啦啦??"))
}
}
defer
使用關(guān)鍵字defer
寫一個(gè)代碼塊涌萤,它會(huì)在這個(gè)函數(shù)內(nèi)所有代碼執(zhí)行后,執(zhí)行口猜。(也就是這個(gè)函數(shù)返回之前)
無論這個(gè)函數(shù)是否會(huì)拋出一個(gè)錯(cuò)誤负溪,這塊代碼都會(huì)執(zhí)行
你可以把函數(shù)內(nèi)掃尾的代碼,和執(zhí)行下一個(gè)函數(shù)前的代碼結(jié)合在這里济炎,雖然它們的執(zhí)行時(shí)機(jī)不同川抡。
var fridgeIsOpen = false
let fridgeContent = ["milk", "eggs", "leftovers"]
func fridgeContains(_ food: String) -> Bool {
fridgeIsOpen = true
defer {
fridgeIsOpen = false
}
let result = fridgeContent.contains(food)
return result
}
fridgeContains("banana")
print(fridgeIsOpen)
- Generics
// Created by Hunter on 22/01/2017.
// Copyright ? 2017 Hunter. All rights reserved.
//
import UIKit
enum OptionalValue<Wrapped> {
case None
case Some(Wrapped)
}
class GenericsTestVC: UIViewController {
/*
尖括號(hào)里面寫一個(gè)名字,創(chuàng)建一個(gè)泛型函數(shù)或者類型
*/
private func makeArray<Item>(repeating item: Item, numberOfTimes: Int) -> [Item] {
var result = [Item]()
for _ in 0..<numberOfTimes {
result.append(item)
}
return result
}
private var possibleInteger: OptionalValue<Int> = .None
override func viewDidLoad() {
super.viewDidLoad()
print(makeArray(repeating: "哈哈??", numberOfTimes: 5))
print(possibleInteger)
possibleInteger = .Some(100)
print(possibleInteger)
/*
在類型名后面使用where來指定對(duì)類型的需求须尚,比如崖堤,限定類型實(shí)現(xiàn)某一個(gè)協(xié)議,限定兩個(gè)類型是相同的耐床,或者限定某個(gè)類必須有一個(gè)特定的父類密幔。
*/
@discardableResult
func anyCommonElements<T: Sequence, U: Sequence>(_ lhs: T, _ rhs: U) -> Bool
where T.Iterator.Element: Equatable, T.Iterator.Element == U.Iterator.Element {
for lhsItem in lhs {
for rhsItem in rhs {
if lhsItem == rhsItem {
return true
}
}
}
return false
}
print(anyCommonElements([1, 2, 3], [3]))
}
}