swift之面向对象

都说类和对象是面向过程语言开发和面向对象语言开发的区别

我们定义一个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 :不注销会崩溃

你可能感兴趣的:(swift之面向对象)