Objective-C协议遵守NSObject协议的原因
来源:互联网 发布:水印软件 编辑:程序博客网 时间:2024/06/06 08:08
来自我的个人博客Minecode.link
今天将用OC写的框架迁移至Swift时,发现OC写的协议都遵守了NSObject,而在Swift中没有此协议。所以记录一下这个问题的原因:
在Objective-C 2.0之后,方法修饰符有@required和@optional(新增),也就是说增加了可选方法。对应的,也就需要在调用代理方法之前判断其是否被实现。也就是我们熟悉的如下写法:
if (self.delegate != nil && [self.delegate respondsToSelector:@selector(protocolFunc)]) { [self.delegate protocolFunc];}
NSObject的协议主要定义了以下几个常见方法:
- - (BOOL)isKindOfClass:(Class)aClass;
- - (BOOL)isMemberOfClass:(Class)aClass;
- - (BOOL)conformsToProtocol:(Protocol *)aProtocol;
- - (BOOL)respondsToSelector:(SEL)aSelector;
- etc…
这就是为什么我们需要继承NSObject。
而Swift语言为我们提供了可选项,保证了调用的安全性,所以我们可以按如下方法使用:
// 定义协议@objc protocol MCTestViewDelegate: class { @objc func testViewNeedsOperate() @objc optional func testViewDidUpdate()}/* ... */// 判断是否遵守协议并调用if let delegate = testView is MCTestViewDelegate { delegate.testViewNeedsOperate()}// 判断代理对象是否实现该代理方法if (delegate as? MCTestViewDelegate)?.testViewDidUpdate != nil { // 处理...}// 一句话实现(delegate as? MCTestViewDelegate)?.testViewDidUpdate?()
通过可选项的判断,即可轻松判断方法/协议是否实现,减少了代码量。
阅读全文