在过去-不太久远的过去-我害怕闭包。我尽可能的躲避。这些大括号和一些奇怪的单词,completionHandler, @escaping 似乎是艰巨的和不可逾越的。
如果你不经常使用闭包, 不要担心。我告诉你如何做好, 不管如何, 我希望我的读者理解一个函数返回一个值的含义。
动机
函数编程在iOS中很流行,里面包含闭包。什么? 为什么? 怎么做? 好的, 我想我们现在讨论这种关系还为时过早。这就像没有牙齿的人想吃肉。如果没有坚实的基础, 很难把它吞咽下去。我希望我能能在第二部分平稳实现。
我认为你可以学会的
闭包的含义, 高阶函数, 一级函数, 这些东西对你来说可能有些陌生, 好吧, 让我们一起学习吧。
你是谁,闭包?
当我像我13岁的姐姐解释时, 我会说这是一个没有关键字func, 没有名字的函数。从初学者的视角看,闭包是赤裸裸的并且是不完整的。
让我们来比较一下然后在函数和闭包添加两个数字, 两者都有两个Int类型的参数和一个Int类型的返回值。让我们先从函数开始吧。
//函数
func addTwoNumbers(number1: Int, number2: Int) -> Int {
return number1 + number2
}
var storedFunc = addTwoNumbers
storedFunc(5, 9) // 14
我将函数addTwoNumber 存储到新创建的变量storedFunc中, 但是这怎么可能呢? 在Swift 3中就像许多其他编程语言一样。Swift函数被描述为一级函数。我不知道为什么会这样叫, 到那时你可以用一个变量或者常量存储一个函数。
我们不用 func 关键字存储函数。实际上,我们可以使用闭包。
var storedClosure: (Int, Int) -> Int = { (number1, number2) in
return number1 + number2
}
storedClosure(number1: 5, number2: 9) // 14
上面的事例和第一个一样。 In 关键字用于将输入参数number1, number2 和 返回值部分分离的。我们已经说过 storedClosure 是 (Int, Int) -> Int。预先声明的类型告诉变量它接受两个参数并返回一个Int类型的值。
我希望到现在, 你已经开始理解闭包是一个没有名称和func关键字的函数。或者,你可以说函数是一个冗长的闭包。
但是, 上面的例子可以被简化,并且, 是的, 它仍然被称为闭包
//简化
var storedClosure1: (Int, Int) -> Int = { return $0 + $1 }
//再简化
var storedClosure2: (Int, Int) -> Int = { $0 + $1 }
那么 $0 和 $1 代表什么? 这只是Swift的语法。系统会自动识别出两Int类型的参数。第一个输入的是 $0 ,之后的是 $1。 我们甚至不需要返回,如果你只是在测试这两个参数的使用。如果你想在闭包上增加一点亮点,比如打印一些东西。
var storedClosure3: (Int, Int) -> Int = { (number1, number2) in
print("Hello")
return number1 + number2
}
大字提醒
到目前为止,您已经了解了闭包和函数几乎是相同的,并且它们都是一类的,因为您可以将它们存储到一个变量中。它们被称为,高阶函数。什么? (再说一次,我不知道这个名字来自哪里)。你可以使用闭包/函数作为参数,甚至返回它们。
例如可以将函数插入到函数中, 让我们试着插入一个返回打印函数, “hello world”在一个函数。函数包含一个参数,类型为() -> String
func insertSomething(closure: () -> String) {
closure()
}
现在是添加一个返回hello world的函数的时候了
func returnHelloWorld() -> String {
print("Hello World")
return "Hello World"
}
调用
insertSomething(closure: returnHelloWorld) // "Hello World"
回顾一下,你已经插入了返回值是一个字符串的函数returnHelloWorld,在函数 insertSomething 中。如果你想添加一个闭包作为参数,你可以这样做,
var closureHelloWorld: () -> String = { return "hello" }
insertSomething(closure: closureHelloWorld) // "hello"
如果你想添加一些东西,你可以这样做。
insertSomething(closure: { return "hello world"}) // "hello world"
翻译自:No Fear Closure in Swift with Bob