一、继承与重写, 防止重写

1.1 基类, 不继承任何类. Swift不想OC或者Java中继承自Object类.定义一个类,不继承任何类,该类就是基类.

[java] view
plain
copy

  1. class Person1{   //这个Person1就是基类
  2. func eat(){
  3. println("eat a pig!")
  4. }
  5. }

1.2 继承. Swift为单继承

[java] view
plain
copy

  1. class XiaoMing1 : Person1{
  2. var name = "xiaoming"
  3. }

1.3 重写. 必须加关键字override. (OC,Java中是不必加的)

[java] view
plain
copy

  1. class XiaoHong1 : Person1{
  2. override func eat() {
  3. super.eat();  //可以用super来调用父类中的属性与方法
  4. println("xiaohong eat a pig")
  5. }
  6. }
  7. var xh = XiaoHong1()
  8. xh.eat()

1.4 重写属性(存储属性与计算属性)

可以用get/set/willSet/didSet进行属性重写

可以将一个只读属性重写为一个读写属性,不可以将一个读写属性重写为一个只读属性

也就是说: 重写的范围只能是 小-->大 (类似Java)

子类重写父类的属性时, 不管父类是计算属性还是存储属性, 重写的过程就是重写其中的get/set等, 子类的override都是计算属性的格式

[java] view
plain
copy

  1. class Person2{
  2. var name:String{ //计算属性
  3. set{
  4. println("Person2 set")
  5. }
  6. get{
  7. return "Person2"
  8. }
  9. }
  10. let age: Int = 10  //常量存储属性
  11. var height:Int = 175  //变量存储属性
  12. }
  13. class XiaoMing2 : Person2{
  14. override var name:String{
  15. set{
  16. super.name = newValue  //将父类的值设置为新值
  17. println("XiaoMing2 set")
  18. }
  19. get{
  20. return "XiaoMing2"
  21. }
  22. }
  23. override var age : Int{   //如果父属性是var的话, 必须有get和set
  24. get{
  25. println(super.age)
  26. return 20
  27. }
  28. }
  29. override var height :Int{  //重写观察属性: 继承来的常量存储属性,只读计算属性不能添加观察器.
  30. didSet{  //注意有didSet,willSet的地方是不能出现get/set的
  31. println("didset----\(oldValue)")
  32. }
  33. willSet{
  34. println("willSet----\(newValue)")
  35. }
  36. }
  37. }
  38. var xm2 = XiaoMing2()
  39. xm2.name = "XM2"
  40. println(xm2.age)
  41. xm2.height = 10

1.5 防止重写(final). 与Java一样

[java] view
plain
copy

  1. //可将final写在属性/方法/类等前面
  2. class Person3{
  3. final var name = "Person3"
  4. }
  5. class XiaoMing3{
  6. //override var name ...//这样会报错
  7. }

二、构造器

Swift中的构造器无返回值(OC中是返回id的), 它的主要任务是保证新实例在第一次使用前完成正确的初始化工作.

init() , 可以重载

2.1 默认构造器与带参数构造器, 继承器的重载

[java] view
plain
copy

  1. class Person4{
  2. var name : String  //必须初始化, 或者在构造函数中初始化
  3. //默认, 不带参数
  4. init(){  //无返回值
  5. name = "xuneng"
  6. }
  7. //带参数
  8. init(name :String){  //默认是以参数名作为外部参数名的
  9. self.name = name + "Hello"  //和OC中相同, 用self.(Java中用this)
  10. }
  11. //带可选参数. 可选类型: 可以为空,也可以以后赋值. 初始化为nil
  12. var age:Int = 10
  13. init(name :String , age:Int?){
  14. self.name = name
  15. self.age = age!   //可选参数必须确定有(加!号)才能赋值
  16. }
  17. }
  18. var p4 = Person4()  //默认就是没有括号的
  19. var p4_1 = Person4(name: "xn4545945 ")  //参数名作为外部参数名
  20. var p4_2 = Person4(name: "neng", age: 10)

2.1 指定构造器(Designated initializer)与便利构造器(convenience initializer)

2.1.1 指定构造器: 每个类必须至少有一个,用来确保所有值都进行初始化.(会根据父类的继承关系往上调用,完成父类的初始化)

[java] view
plain
copy

  1. //Person4中的3个构造器都是指定构造器, 都需要进行所有成员变量的初始化

2.1.2 便利构造器(加convenience关键字):辅助性的构造器.可以用来同一个类中的指定构造器,也可以用来创建一个有特定输入的实例

[java] view
plain
copy

  1. class Person5{
  2. var name : String  //必须初始化, 或者在指定构造函数中初始化
  3. init(name :String){ //指定构造器
  4. self.name = name + "Hello"
  5. }
  6. convenience init(name :String , height:Int){  //便利构造器. 不需要全部初始化成员变量
  7. self.init(name:name)
  8. println(height)
  9. }
  10. }
  11. var p5 = Person5(name: "xn4545945", height: 175)

2.2 构造器链(概念):  规范指定构造器与便利构造器间的调用关系.

[java] view
plain
copy

  1. //1) 规则1: 指定构造器必须调用其父类的指定构造器
  2. //2) 规则2: 便利构造器必须调用同一类中调用的其他构造器
  3. //3) 规则3: 便利构造器必须以调用一个指定构造器结束

一句话总结上面3个规律: 指定构造器是向上调用的,便利构造器是横向调用的.

2.3 两段式构造过程 (概念)

第一个阶段:每个存储型属性通过引入它们的类的构造器来设置初始值。

第二阶阶段:当每一个存储型属性值被确定后,二阶段开始,它给每个类一次机会在新实例准备使用之前进一步定制它们的存储型属性。

两段式构造过程的使用让构造过程更安全,同时在整个类层级结构中给予了每个类完全的灵活性。

Swift 的两段式构造过程跟 Objective-C中的构造过程类似。最主要的区别在于阶段一,Objective-C给每一个属性赋值 0或空值(比如说 0或 nil)。Swift的构造流程则更加灵活,它允许你设置定制的初始值,并自如应对某些属性不能以 0或 nil作为合法默 认值的情况。

2.4 构造器的继承(概念)

与OC不同, Swift中子类不会默认继承父类的构造器.
(但如果满足以下2个条件会自动继承)

1)如果子类没有定义指定构造器, 那么他将主动继承父类的

2)如果子类提供了所有父类指定构造器的实现, 那么自动继承父类的便利构造器

[java] view
plain
copy

  1. class Father{
  2. init(){
  3. println("father init")
  4. }
  5. convenience init(name:String){
  6. self.init();
  7. println("father convenience init")
  8. }
  9. }
  10. class Son:Father{
  11. override init(){ //子类实现了父类的全部指定构造器, 因而会自动继承父类的便利构造器
  12. println("son init")
  13. }
  14. }
  15. var son1 = Son()
  16. var son2 = Son(name: "xuneng")  //自动继承了父类的便利构造器

2.5 通过闭包和函数来设置属性的默认值

[java] view
plain
copy

  1. //闭包的一般格式
  2. class SomeClass{
  3. let someProperty : Int = { //整个花括号表示一个闭包
  4. return 0
  5. }() //这个小括号不能丢, 表示立即执行闭包. 并返回值.
  6. }

1)如果某个存储属性的值需要特别定制, 则可以使用闭包或全局函数类提供默认值.

2)当类型创建时, 闭包或函数会被调用,他们的返回值会被当做默认值赋值给这个存储属性.

3)使用闭包时, 实例的其他部分并没有初始化, 因而不能在闭包里面访问:其他实例属性/self属性/实例方法等.

[java] view
plain
copy

  1. class Person6{
  2. let name : String = {//可以在闭包里面做一些复杂的初始化工作
  3. let firstName = "xu"
  4. let lastName = "neng"
  5. return firstName + lastName
  6. }()
  7. }
  8. var p6 = Person6()
  9. println(p6.name)

三、析构(反初始化) deinit

在一个类实例被释放之前, 反初始化函数被立即调用

Swift通过ARC来处理实例的内存管理, 与OC一样.

每个类只有一个反初始化函数, 不带任何参数. 且不允许主动调用.

子类继承了父类的反初始化函数(释放顺序类似Java. 先释放子类-->父类)

反初始化话方法能访问该实例的所有属性

[java] view
plain
copy

  1. class Person7{
  2. var myMoney:Int
  3. init(){
  4. myMoney = 10
  5. }
  6. deinit{
  7. myMoney = 0   //可以访问类中的变量. 但这句没用. 因为销毁了,成员变量即不存在了
  8. //可以做一些清理工作
  9. }

【iOS】Swift类的继承、构造方法、析构器等复习的更多相关文章

  1. Swift—类的继承-备

    Swift中的继承只能发生在类上,不能发生在枚举和结构体上.一个类可以继承另一个类的方法.属性.下标等特征,当一个类继承其他类时,继承类叫子类,被继承类叫父类(或超类).子类继承父类后,可以重写父类的 ...

  2. swift类、继承、接口

    import Foundation class Hello{ var _name:String?="swift global" init(name:String){ //定义类中有 ...

  3. Swift互用性: 使用Objective-C特性编写Swift类(Swift 2.0版)-b

    本节包括内容: 继承Objective-C的类(Inheriting from Objective-C Classes) 采用协议(Adopting Protocols) 编写构造器和析构器(Writ ...

  4. Swift 析构器deinit

    析构器只适用于类类型,当一个类的实例被释放之前,析构器会被立即调用.析构器用关键字deinit来标识,类似于构造器用init来标识. 原理: Swift会自动释放不再需要的实例以释放资源.Swift通 ...

  5. swift 学习- 17 -- 析构器

    // 析构器 只适用与 类类型, 当一个类的实例被释放之前, 析构器会被立即调用, 析构器用关键字 deinit 来标示, 类似于构造器要用 init 来标示 // 析构过程原理 // Swift 会 ...

  6. Swift构造器(Initializer)与析构器(Deinitializer)

    为了初始化结构体和类等类型的实例属性. 默认构造器 struct Fahrenheit { var temperature: Doubleinit(){ temperature = 32.0 } } ...

  7. Swift中子类必须包含的构造器和析构器

    import Foundation /* Swift中子类必须包含的构造器 1.Swift允许在父类构造器前添加required关键字, 用于声明所有子类必须包含该required构造器 (如果没有声 ...

  8. 《从零开始学Swift》学习笔记(Day 41)——类的继承

    原创文章,欢迎转载.转载请注明:关东升的博客 Swift中的继承只能发生在类上,不能发生在枚举和结构体上.一个类可以继承另一个类的方法.属性.下标等特征,当一个类继承其他类时,继承类叫子类,被继承类叫 ...

  9. 0604-面向对象、类与对象、类、static、构造方法/析构方法

    一.面向对象 1.面向过程:一个人分步骤完成某个事情 2.面向对象:某件事情拆分为多个任务,由每个对象独立完成,最后调用整合为一个完整的项目 3.三要素:继承.封装.多态. 封装:私有化属性 提供公共 ...

随机推荐

  1. Delphi基础-数据类型

    枚举类型 Pascal程序不仅用于数值处理,还更广泛地用于处理非数值的数据.例如,性别.月份.星期几.颜色.单位名.学历.职业等. ​ 1. 枚举类型的定义 格式: type 枚举类型标识符=(标识符 ...

  2. Redis进阶实践之十六 Redis大批量增加数据

    一.介绍      有时,Redis实例需要在很短的时间内加载大量先前存在或用户生成的数据,以便尽可能快地创建数百万个键.这就是所谓的批量插入,本文档的目标是提供有关如何以尽可能快的速度向Redis提 ...

  3. 新的一年新的变化!IT的大变天

    今天是一个特别的日子,祝女神朋友们,节日快乐,早点下班! 新的一年,大家又忙碌在加班加点的堆代码中,bug的陪伴使我快乐使我忧伤,想想想,也奋斗了五六百的岁月,实习期向往大城市的公司,梦想着有一天与自 ...

  4. C# Redis实战(二)

    二.Redis服务  在C# Redis实战(一)中我将所有文件拷贝到了D盘redis文件夹下,其中redis-server.exe即为其服务端程序,双击即开始运行,如图             可以 ...

  5. centos7的服务管理

    1,启动服务(每条都可以)systemctl start httpdsystemctl start httpd.serviceservice httpd start 2,停止服务systemctl s ...

  6. python 全栈开发,Day4(正式)

    一.列表 列表是python中的基础数据类型之一,它是以[]括起来,每个元素以逗号隔开,而且他里面可以存放各种数据类型比如: li = ['alex',123,Ture,(1,2,3,'wusir') ...

  7. 针对微信的一篇推送附有的数据链接进行MapReduce统计

    原推送引用:https://mp.weixin.qq.com/s/3qQqN6qzQ3a8_Au2qfZnVg 版权归原作者所有,如有侵权请及时联系本人,见谅! 原文采用Excel进行统计数据,这里采 ...

  8. 原生js+canvas实现滑动拼图验证码

    上图为网易云盾的滑动拼图验证码,其应该有一个专门的图片库,裁剪的位置是固定的.我的想法是,随机生成图片,随机生成位置,再用canvas裁剪出滑块和背景图.下面介绍具体步骤. 首先随便找一张图片渲染到c ...

  9. shiro授权

    一.shiro-permission.ini shiro-permission.ini里面的内容相当于在数据库 #用户 [users] #用户zhang的密码是123,此用户具有role1和role2 ...

  10. 1-2 Spring 的基本使用

    1.Spring容器的配置文件applicationContext.xml的引入 名称可以自己定义 <?xml version="1.0" encoding="UT ...