简介:本文主要讲:函数的定义,外部参数的用处,无返回类型的三种函数定义方式
闭包的定义,闭包的概念和用法,尾随闭包的写法,解除循环引用的方法
一、函数:
代码实现
- 函数的定义
- 格式
func 函数名(行参列表) -> 返回值 {代码实现}
- 调用
let result = 函数名(值1, 参数2: 值2...)
func sum(a: Int, b: Int) -> Int { return a + b } let result = sum(10, b: 20)
func demo(str: String) -> Void { print(str) } func demo1(str: String) -> () { print(str) } func demo2(str: String) { print(str) } demo("hello") demo1("hello world") demo2("olleh")
- 外部参数
- 在形参名前再增加一个外部参数名,能够方便调用人员更好地理解函数的语义
- 格式:
func 函数名(外部参数名 形式参数名: 形式参数类型) -> 返回值类型 { // 代码实现 }
- Swift 2.0 中,默认第一个参数名省略
func sum1(num1 a: Int, num2 b: Int) -> Int { return a + b } sum1(num1: 10, num2: 20)
二、闭包:
与 OC 中的 Block 类似,闭包
主要用于异步操作执行完成后的代码回调,网络访问结果以参数的形式传递给调用方
闭包的定义
- 定义一个闭包
- 闭包 = { (行参) -> 返回值 in // 代码实现 }
in
用于区分函数定义和代码实现
- 最简单的闭包,如果没有参数/返回值,则
参数/返回值/in
统统都可以省略
let demoFunc = { print("hello") }
基本使用
GCD 异步
func loadData() { dispatch_async(dispatch_get_global_queue(0, 0), { () -> Void in print("耗时操作 \(NSThread .currentThread())") }) }
- 尾随闭包,如果闭包是最后一个参数,可以用以下写法
- 注意上下两段代码,
}
的位置
func loadData() { dispatch_async(dispatch_get_global_queue(0, 0)) { () -> Void in print("耗时操作 \(NSThread .currentThread())") } }
func loadData() { dispatch_async(dispatch_get_global_queue(0, 0)) { print("耗时操作 \(NSThread .currentThread())") } }
自定义闭包参数,实现主线程回调
override func viewDidLoad() { super.viewDidLoad() loadData { print("完成回调") } }
override func viewDidLoad() { super.viewDidLoad() loadData4 { (html) -> () in print(html) } }
循环引用
class NetworkTools: NSObject {
class ViewController: UIViewController { var tools: NetworkTools? override func viewDidLoad() { super.viewDidLoad() tools = NetworkTools() tools?.loadData() { print("come here \(self.view)") } }
运行不会形成循环引用,因为 loadData 执行完毕后,就会释放对 self 的引用