经验首页 前端设计 程序设计 Java相关 移动开发 数据库/运维 软件/图像 大数据/云计算 其他经验
当前位置:技术经验 » 移动开发 » iOS » 查看文章
记,NSProxy需要实现哪些方法?
来源:cnblogs  作者:米太白  时间:2019/5/5 8:55:55  对本文有异议

转注出:https://www.cnblogs.com/xiaobajiu/p/10799962.html

使用NSProxy做替身,代理,多继承,本质上都是用它来转发消息给真身。

观察头文件,NSProxy自身实现了的方法如下:

  1. + (Class)class;//类方法不应该重写

  2. //普通消息转发1
  3. - (void)forwardInvocation:(NSInvocation *)invocation;//其实自身并没有实现,调用报错。需要子类实现。并且官方建议重写。
    //普通消息转发2
  4. - (nullable NSMethodSignature *)methodSignatureForSelector:(SEL)sel;//可以重写,并且官方建议重写。
  5. - (void)dealloc;//可以重写
  6. - (void)finalize;//应该忽略的方法(垃圾回收)
  7. @property (readonly, copy) NSString *description;//可以重写
  8. @property (readonly, copy) NSString *debugDescription;//可以重写
  9. + (BOOL)respondsToSelector:(SEL)aSelector;//类方法不应该重写

另外值得注意的是被注释的快速转发消息方法:

  1. // - (id)forwardingTargetForSelector:(SEL)aSelector;

官方明确的暗示我们要使用上上方代码块里的普通消息转发。其实NSproxy子类对象是响应这个方法的,探究这行注释的原因主要是因为协议<NSObject>

 

  1. - (BOOL)isEqual:(id)object;//可以重写,内部只比较地址没比较哈希
  2. @property (readonly) NSUInteger hash;//可以重写,注意内部返回的是对象地址<<3
  3. @property (readonly) Class superclass;//可以重写
  4. - (Class)class;//可以重写
  5. - (instancetype)self;//可以重写,一般忽略
  6.  
  7. - (id)performSelector:(SEL)aSelector;//可以重写
  8. - (id)performSelector:(SEL)aSelector withObject:(id)object;//可以重写
  9. - (id)performSelector:(SEL)aSelector withObject:(id)object1 withObject:(id)object2;//可以重写
  10.  
  11. - (BOOL)isProxy;//返回YES,一般忽略
  12.  
  13. - (BOOL)isKindOfClass:(Class)aClass;//被主动转发到自身的forwardInvocation:中处理
  14. - (BOOL)isMemberOfClass:(Class)aClass;//被主动转发到自身的forwardInvocation:中处理
  15. - (BOOL)conformsToProtocol:(Protocol *)aProtocol;//被主动转发到自身的forwardInvocation:中处理
  16.  
  17. - (BOOL)respondsToSelector:(SEL)aSelector;//如果不能响应也会被主动转发到自身的forwardInvocation:中处理
  18.  
  19. - (instancetype)retain OBJC_ARC_UNAVAILABLE;
  20. - (oneway void)release OBJC_ARC_UNAVAILABLE;
  21. - (instancetype)autorelease OBJC_ARC_UNAVAILABLE;
  22. - (NSUInteger)retainCount OBJC_ARC_UNAVAILABLE;
  23. - (struct _NSZone *)zone OBJC_ARC_UNAVAILABLE;
  24. @property (readonly, copy) NSString *description;//可以重写
  25. @optional
  26. @property (readonly, copy) NSString *debugDescription;//可以重写

 

这里注意到了4个很特殊的方法:

  1. - (BOOL)isKindOfClass:(Class)aClass;
  2. - (BOOL)isMemberOfClass:(Class)aClass;
  3. - (BOOL)conformsToProtocol:(Protocol *)aProtocol;
  4. - (BOOL)respondsToSelector:(SEL)aSelector;

前3个方法直接要求使用普通消息转发来实现,所以一调用就跳进普通消息转发从而绕开了快速转发(- (id)forwardingTargetForSelector:(SEL)aSelector;

NSProxy并没有实现forwardInvocation:如果用户也没有实现的话它一定会产生崩溃。同理,末尾方法如果自身不能响应依然会要求使用普通消息转发来实现。

第一个总结:

如果在NSProxy中只想使用快速转发来完成功能的话就:1.必须单独实现以上4个方法,或者2.既实现快速转发又实现普通转发;显然1比较划算。

 

第二个结论:

如果要极尽完全地实现把所有消息都转发给内部的真身,那么应该要把上方标记'可以重写'的方法都重写了。

原文链接:http://www.cnblogs.com/xiaobajiu/p/10799962.html

 友情链接:直通硅谷  点职佳  北美留学生论坛

本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728

W3xue 的所有内容仅供测试,对任何法律问题及风险不承担任何责任。通过使用本站内容随之而来的风险与本站无关。
关于我们  |  意见建议  |  捐助我们  |  报错有奖  |  广告合作、友情链接(目前9元/月)请联系QQ:27243702 沸活量
皖ICP备17017327号-2 皖公网安备34020702000426号