在Swift中,用满足ErrorType协议类型来表示Error。
enum vendingMachingError: ErrorType { case InvalIDSelection case InsufficIEntFunds(required: Double) case OutOfStock }
为了表明一个函数或者方法会抛出错误,你需要在它的声明之后添加throws关键字,如果不提前声明,则不可抛出错误。
func canThrowErrors() throws -> String func cannotthrowErrors() -> String
在可抛出错误的函数体中的任意位置都可用throw语句抛出错误。
struct Item {
var price: Double
var count: Int
}
var inventory = [
"Candy bar" : Item (price: 1.25 ,count: 7 ),
"Chips" : 1.00 ,216)">4 ),27)">"Pretzels" : 0.75 ,216)">11 )
]
var amountDeposited = 1.00
func vend(itemnamed name: String ) throws {
guard var item = inventory [name] else {
throw
vendingMachingError . InvalIDSelection
}
guard item. count > 0 throw @H_826_404@OutOfStock
}
if amountDeposited >= item. price {
amountDeposited -= item. price
--item. count
inventory [name] = item
} let amountrequired = item. price - amountDeposited
InsufficIEntFunds (required: amountrequired)
} }
在你调用一个可能throw的函数时,你需要在前面加上try关键字。
let favoriteSnacks = [
"Alice" : "Chips" ,27)">"Bob" : "licorice" ,27)">"Eve" : "Pretzels"
]
func buyFavoriteSnacks(person: let snackname = favoriteSnacks [person] ?? "Candy bar"
try vend (itemnamed: snackname)
}
如果在某些情况下你知道一些可抛出错误的函数在运行时不会抛出错误,你可以使用try!关键字来代替普通的try。
func willOnlyThrowIfTrue(value: Bool ) throws {
if value {
throw someError
}
do {
try willOnlyThrowIfTrue ( false )
} catch {
//Handle Error
}
}
try ! false )
defer关键字内的语句直到离开当前代码块时才会被执行。这些语句让你能做一些必要的清理工作,不论当前代码块内有没有错误出现,defer内的语句都会执行。而且defer的执行顺序和它们被定义的顺序是相反的,比如第一个定义的defer会在第二个定义的defer之后执行。
func processfile(filename: String ) if exists(filename) {
let file = open(filename)
}
defer {
close (file)
}
while let line = try file.readline() {
//Work with the file.
}
//close(file) is called here,at the end of the scope. } 总结
以上是内存溢出为你收集整理的Swift 2.0语法更新(一)全部内容,希望文章能够帮你解决Swift 2.0语法更新(一)所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)