一、闭包
1、可以理解成OC中的block
2、一段预先准备好的代码
3、可以当做参数传递
4、在需要的时候执行
5、形参,返回值,代码都包括在{}中,in用了分隔 形参返回参和执行代码
6、格式 {(形参列表) -> 返回值类型 in 函数代码}
7、尾随闭包,闭包是最后一个参数,函数的()可以提前关闭,最后一个参数直接使用{代码实现}
let demoFunc = {
print("hello")
}
demoFunc()执行闭包
let demoFunc1 = { (x:Int,y:Int) -> Int in
return x + y
}
demoFunc1(10,y:20)
尾随闭包:
dispatch_async(dispatch_get_global_queue(0,0)){() -> void in
}
非尾随闭包:
dispatch_async(dispatch_get_global_queue(0,0),{() -> void in
})
二、自定义视图的构造函数
1、函数支持重载,函数名相同,参数的数量和类型不同
init(frame:CGRect,numbers:Int)
三、构造函数
1、如果没有实现构造函数,会执行父类的构造函数
2、非可选项存储型属性没有设置初始值,要在构造函数中设置初始值
3、构造函数的作用,给本类的属性分配空间,给本类的属性设置初始化值,调用父类的init()实例化父类的属性
4、默认情况下,系统会自动调用父类的构造函数
5、在同一个命名空间下,默认所有的类都是全局共享的,不需要做任何引用就可以直接使用,在默认情况下,命名空间就是项目名称
6、如果父类提供了多个构造函数,子类的构造函数必须指定父类的构造函数
7、如果没有实现Init()构造函数,一旦实现了其他的构造函数,默认的Init()构造函数将无法被访问
8、先给参数赋值,然后再调用父类的构造函数,和oc相反
9、convenience,便利构造函数
(1)默认情况下,所有的构造方法都是指定构造函数 Designated
(2)convenience关键字修饰的构造函数是便利构造函数
(3)便利构造函数可以返回nil
(4)只有便利构造函数中可以调用self.init()
(5)便利构造函数不能被继承
convenience init?(age:Int){
if age > 100:{
return nil
}
self.init(dic)
}
四、deinit析构函数
1、类似于oc中的dealloc,对象被释放之前调用,可以用于释放资源,举个例子,某一个类中开启了一个定时器,就可以在析构函数中停止
2、写法,没有func,没有()
deinit {
}
3、不能被重载
4、不能直接被调用,会被自动调用
5、先释放子类的属性,再释放父类的属性