Swift 可选接口

Objective-C 中的 Protocol 里存在 @optional 关键字,被这个关键字修饰的方法并不是必需要被实现。好比最多见的 UITableViewDataSource 和 UITableViewDelegate。可是在 Swift 中的 Protocol 的全部方法都是必须被实现的。那么咱们怎么样才能在 Swift 实现可选接口呢?swift

  • @objc & optional
  • 接口扩展

@objc & optional

@objc protocol MyProtocol {
    func doSomething()
    
    @objc optional func doSomething_optional()
}

class MyClass: NSObject, MyProtocol {
    func doSomething() {
        
    }
}

/// 编译不经过
/// Non-class type 'MyStruct' cannot conform to class protocol 'MyProtocol'
struct MyStruct: MyProtocol {
    
}
复制代码

原生的 Swift Protocol 里是没有可选项的,全部定义的方法都是必须被实现的。若是咱们须要像 Objective-C 里那样定义可选的方法,能够直接将接口自己定义为 Objective-C 的。bash

优点

  • 直接以 Objective-C 的接口使用方式来使用。

劣势

  • 使用 @objc 修饰的 Protocol 就只能被 class 实现。对于 struct 和 enum 类型,咱们没法实现此种方式定义的接口。

接口扩展

extension MyProtocol {
    func doSomething_optional() {
        print("Default implementing by extension protocol.")
    }
}

class MyClass: MyProtocol {
    func doSomething() {
        // do something
    }
}

struct MyStruct: MyProtocol {
    func doSomething() {
        // do something
    }
}

enum MyEnum: MyProtocol {
    func doSomething() {
        // do something
    }
}
复制代码

虽然 Swift 中定义的 Protocol 的方法都是必须实现的,可是咱们能够利用 protocol extension 的方式给出部分方法的默认实现。ui

优点

  • 利用 extension 给出默认实现的接口能够供 class、struct 及 enum 使用。

劣势

  • 对于有返回值的接口,默认实现老是须要提供一个合适的返回值,可是并不老是有合适的默认值返回。

例如:spa

protocol MyProtocol {
    func calculateRadian() -> Double
}
复制代码

这里的 Protocol 定义的方法返回一个计算出来的弧度,可是这时咱们就很难找到一个合适的默认值去默认实现接口的方法。code


参考

Swifter 100 个 SWift 必备 Tipsorm

相关文章
相关标签/搜索