** 方式一:利用typealias最完整的创建**
//为(_ num1: Int, _ num2: Int) -> (Int) 类型的闭包定义别名:Add
typealias Add = (_ num1: Int, _ num2: Int) -> (Int)
//创建一个 Add 类型的闭包常量:addCloser1
let addCloser1: Add
//为已经创建好的常量 addCloser1 赋值
addCloser1 = {
(_ num1: Int, _ num2: Int) -> (Int) in
return num1 + num2
}
//调用闭包并接受返回值
let result = addCloser1(20, 10)
形式二:闭包类型申明和变量的创建合并在一起
//创建一个 (_ num1: Int, _ num2: Int) -> (Int) 类型的闭包常量:addCloser1
let addCloser1: (_ num1: Int, _ num2: Int) -> (Int)
//为已经创建好的常量 addCloser1 赋值
addCloser1 = {
(_ num1: Int, _ num2: Int) -> (Int) in
return num1 + num2
}
//调用闭包并接受返回值
let result = addCloser1(20, 10)
形式三:省略闭包接收的形参、省略闭包体中返回值
//创建一个 (Int, Int) -> (Int) 类型的闭包常量:addCloser1
let addCloser1: (Int, Int) -> (Int)
//为已经创建好的常量 addCloser1 赋值
addCloser1 = {
(num1, num2) in
return num1 + num2
}
//调用闭包并接受返回值
let result = addCloser1(20, 10)
形式四:在形式三的基础上进一步精简
//创建一个 (Int, Int) -> (Int) 类型的闭包常量:addCloser1 并赋值
let addCloser1: (Int, Int) -> (Int) = {
(num1, num2) in
return num1 + num2
}
//调用闭包并接受返回值
let result = addCloser1(20, 10)
形式五:如果闭包没有接收参数省略in
//创建一个 () -> (String) 类型的闭包常量:addCloser1 并赋值
let addCloser1: () -> (String) = {
return "这个闭包没有参数,但是有返回值"
}
//调用闭包并接受返回值
let result = addCloser1()
形式六:简写的实际参数名
//创建一个 (String, String) -> (String) 类型的闭包常量:addCloser1 并赋值
let addCloser1: (String, String) -> (String) = {
return "闭包的返回值是:\($0),\($1)"
}
//调用闭包并接受返回值
let result = addCloser1("Hello", "Swift!")
说明: 得益于Swift的类型推断机制,我们在使用闭包的时候可以省略很多东西,而且Swift自动对行内闭包提供简写实际参数名,你也可以通过 $0, $1, $2 这样的语法来引用闭包的实际参数值。如果你在闭包表达式中使用这些简写实际参数名,那么你可以在闭包的实际参数列表中忽略对其的定义,并且简写实际参数名的数字和类型将会从期望的函数类型中推断出来。in关键字也能被省略,$0 和 $1 分别是闭包的第一个和第二个 String类型的 实际参数
参考链接:
Swift中闭包的简单使用