首先理清概念,delegate只是一种模式理念,不是具体方法。OK
1.extension继承法:赋予某根类扩展“空方法”,使其子类继承后可重写成为代理。
就要你成为我的奴隶
// A.swiftclass A{ var delegate : B? func doSomething()->(){ B?.delegateFun() }}extension B{ func delegateFun()->(){}}
// B.swiftclass B{ // 虽然本身没有定义任何方法,但是被拓展了一个delegateFun}
// C.swiftclass C : B{ overrIDe func delegateFun()->(){ println("C conform the delegate method!") }}
2.protocal协议法:只要实现了指定protocal即可成为代理
下蛋的鸡就是好鸡
// A.swiftclass A{ var delegate : AProtocal? func doSomething()->(){ delegate?.() }}protocal AProtocal{ func delegateFun()->()}
// B.swiftclass B : AProtocal{ func delegateFun()->() }
3.闭包+Tuple代理:swift中方法也是first class value
这不是人,这不是妖,这是人妖
// A.swiftclass A{ var delegate : (methodA:()->()?,methodB:(float)->(Bool)?)? func doSomething(){ delegate?.methodA?.() delegate?.methodB?.(10.0) } }
4.继承NSObject使用methodForSelector,使用OC中NSObject提供的的“反射”机制完成调用
无耻下作的典范
代码涉及与OC交互,较长省略原理是用NSObject的方法使用字符串获取selector并返回方法,通过OC包装函数指针并返回给swift调用。方法较不安全,无法检查运行时
总结 以上是内存溢出为你收集整理的Swift实现委托代理的N种方式全部内容,希望文章能够帮你解决Swift实现委托代理的N种方式所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)