Swift_ 继承 +协议 +延展 +闭包

. 继承

class nurse:Doctor{
    
    //重写父类方法, 一定要在方法前加 override
    # 注意: 用Static修饰的方法是不可以重写的类方法
    override class func heh() {
        
        print("我是子类, 重写父类的class func 方法")
        
    }
}

nurse.heh()```
***
####. Swift中的协议 
1. 类, 结构体和枚举都可以遵循协议, 并提供具体实现来完成协议定义的方法和功能
2. 任意能够满足协议要求的类型, 被称为遵循(conform)这个协议
3. 使用" @objc " 修饰的协议, 其中的方法可以声明成可选实现(即:optional修饰)

>协议 --> 带有可选择实现函数

@objc protocol Men{
func cook()
func wash()
optional func KO() //使用@objc修饰, 可以有可选择实现的方法
}```


协议 --> 必须实现所有函数

protocol Divid{  
    func lookKid()
}```
***
> 如果类在遵循协议的同时拥有父类, 应该将父类名放在协议之前, 用逗号分隔, 例如:

//声明一个类doc1, 继承于Doctor, 且遵循Men和Divid协议
class doc1: Doctor,Men,Divid {

@objc func cook() {
print("做饭")
}

@objc func wash() {
print("洗衣服")
}

func lookKid() {
print("看孩子")
}
}

let doc:doc1 = doc1(name: "大娃", age: 10)
doc.cook()
doc.wash()
doc.lookKid()```

*Swift中的扩展

扩展(Extension)

  1. extension + 类名或者结构体名(可以对一个类或者结构体扩展方法)
  1. extension可以多次对一个类进行扩展, 也可以给一个类扩展协议方法
  2. 扩展就是向一个已有的类, 结构体和枚举, 添加新功能(方法)
  3. 扩展可以对一个类型添加新功能, 但是不能重写已有的功能(方法)

*. 对一个类进行方法的扩展(添加方法)

extension doc1{
    //扩展对象方法
    func say(){
        
       print("扩展对象的方法")
    }
    
    
    //扩展类方法
    class func eat() {
        
        print("扩展类的方法")
    }
    
}

doc.say()
doc1.eat() //类方法, 只能用类名来调用```

*. 扩展一个类, 遵循的协议中的方法 //给一个类扩展协议方法 , 该方法只能在该处使用

extension doc1{

@objc func Magic(){
    
    print("变魔术")
    
}

}

doc.Magic()```

闭包 ---------

  1. 闭包是自包含的函数代码块, 可以在代码中被传递,使用
  1. Swift中的闭包和OC中的Block, 以及其他语言中的匿名函数类似
  2. 闭包可以捕获和存储其所在上下文中任意的常量和变量, 也就是说闭合并包裹着这些常量和变量
  3. Swift会帮你管理在捕获过程中涉及到的内存操作
  4. 格式:

{(参数名:类型)->返回值类型 in
需要执行的代码
}

  1. 例如:
let backString = {
      (name:String)->String in
      return name
  }```

>7. in: 闭包的函数体部分由关键字" in "引入, 该关键字表示闭包的参数和返回值类型定义已经完成. 闭包函数体即将开始

######闭包代码实例

//求两个数的最大值(三目运算)
//var maxResult:((a:Int, b:Int)->Int)
var maxResult:((a:Int, b:Int)->Int)
//第一种方式:
maxResult = {
(a:Int, b:Int)->Int in
return a > b ? a : b
}
//第二种方式
maxResult = {

a,b in
return a > b ? a : b

}
//第三种方式
maxResult = {
a, b in
a > b ? a : b
}
//第四种方式
maxResult = {
(a, b)->Int in
return a > b ? a : b
}
//第五种方式
maxResult = {
$0 > $1 ? $0 : $1
}
print(maxResult(a: 3, b: 8))```

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容