都说类和对象是面向过程语言开发和面向对象语言开发的区别
我们定义一个Person类,继承于NSObject,关键字为class
class Person: NSObject {
// 1.定义成员变量
var name : String
//2.重写初始化方法
override init() { //override 重写父类方法
name = "1"
super.init()
}
//重载 函数名相同,但是参数和个数不用
init(name : String)
//使用参数的name设置为属性
self.name = name
//调用父类的构造函数
super.init()
}
//使用KVC为本类设置初始值
init(dict: [String : AnyObject]) {
//使用KVC 方法之前,应该调用super.init 保证对象实例化完成
//KVC方法是OC的方法,在运行时给对象发送消息
//要求对象已经实例化完成
super.init()]
setValuesForKeys(dict)
}
//关于便利构造函数
1. 便利构造函数允许返回nil
2. 正常的构造函数一定会创建对象
3. 是为了判断给定的参数是否符合条件,如果不符合条件,直接返回nil,不会创建对象,节省内存
4. 便利构造函数中使用self.init构造当前对象
5. 没有convenience关键字的构造函数是负责创建办对象,反之用来检查条件,本身不负责对象的创建
6. 如果再便利构造函数中使用当前对象的属性,一定要在self.init之后
7. 不能super
convenienceinit?(name:String,age:Int) {
if age >100{
return nil
}
//'self' used before self.init call
self.init()//实例化当前对象,执行到此,self才允许被访问,才能够访问到对象的属性
//执行到此self才允许被访问,才能够访问对象的属性
self.name= name
self.age= age
}
}
关于swift的构造函数:
1.初始化成员变量
2.调用父类初始化方法, 与OC是相反的
3.如果重载了构造函数,并且没有实现父类的init方法,系统不再提 供init()构造函数
默认的构造函数,不能给本类的属性分配空间
关于swift 定义成员变量:
1. 如果成员变量是基本数据类型一定要进行初始化
2. 使用KVC会提示无法找到age的key
3. 基本数据类型,在OC中没有可选,如果定义成可选,运行时同样获取不到,使用KVC就会崩溃
4. 如果是private属性,使用KVC设置值的时候同样无法设置,使用运行时获取不到,KVC就会崩溃
5.在swift4之后使用KVC要加上@objcMembers,表示使用的是OC的方法,否则会崩溃
2.实例化person
let p = Person() //()就相当于OC中的[alloc init]
print(p.name)
注:
swift中有一个deinit函数,相当于OC 中的dealloc,关于这个函数
*没有func 不让调用,
*没有括号,不允许带参数不让重载
* 在对象被销毁前自动调用
应用:跟踪对象被销毁 确认循环引用
NSTimer/CADisplayLink 不销毁会循环引用
通知 不注销不会崩溃,但是会出现内存泄漏
KVO :不注销会崩溃