美文网首页
RxSwift-中介者模式

RxSwift-中介者模式

作者: Code_人生 | 来源:发表于2019-08-06 14:43 被阅读0次

强引用问题 OC版

1、方法一 didMoveToParentViewController

    override func viewDidLoad() {
        super.viewDidLoad()
        self.timerDyz = Timer.scheduledTimer(timeInterval: 1, target: self, selector: #selector(timerFire), userInfo: nil, repeats: true)
    }

    override func didMove(toParent parent: UIViewController?) {
        super.didMove(toParent: parent)
        if parent == nil {
            self.timerDyz?.invalidate()
            self.timerDyz = nil
        }
    }
    
    @objc func timerFire(){
        print("timer fire")
    }
    
    deinit {
        print("\(self) 走了")
    }

2、方法二 block

    override func viewDidLoad() {
        super.viewDidLoad()
        self.timerDyz = Timer.scheduledTimer(withTimeInterval: 1, repeats: true, block: { (timer) in
            print("timer fire dyz")
        })
    }

    deinit {
        self.timerDyz?.invalidate()
        self.timerDyz = nil
        print("\(self) 走了")
    }

3、方法三 引入中间变量

class ViewController: UIViewController {
    
    var timerDyz: Timer?    
    let target = NSObject()

    override func viewDidLoad() {
        super.viewDidLoad()

        class_addMethod(self.target.classForCoder, NSSelectorFromString("timerFiredyz"), method(for: NSSelectorFromString("timerFire")), "v@:")
        timerDyz = Timer.init(timeInterval: 1, target: self.target, selector: NSSelectorFromString("timerFiredyz"), userInfo: nil, repeats: true)
        RunLoop.current.add(timerDyz!, forMode: .common)

//        let sel = NSSelectorFromString("timerFire")
//        let method = class_getInstanceMethod(self.classForCoder, sel)
//        class_addMethod(self.target.classForCoder, sel, method_getImplementation(method!), "v@:")
//        timerDyz = Timer.init(timeInterval: 1, target: self.target, selector: NSSelectorFromString("timerFire"), userInfo: nil, repeats: true)
//        RunLoop.current.add(timerDyz!, forMode: .common)

    }

    @objc func timerFire(){
        print("timer fire")
    }
    
    deinit {
        self.timerDyz?.invalidate()
        self.timerDyz = nil
        print("\(self) 走了")
    }

}

3、方法三 引入中间层

class ViewController: UIViewController {
    let proxy: LGProxy = LGProxy()
    override func viewDidLoad() {
        super.viewDidLoad()
        let selector = NSSelectorFromString("timerFire")
        proxy.lg_scheduledTimer(timeInterval: 1, target: self, selector: selector, userInfo: nil, repeats: true)
    }
    
    @objc func timerFire(){
        print("timer fire")
    }
    
    deinit {
        print("\(self) 走了")
    }
}
class LGProxy: NSObject {
    
    weak var target: NSObjectProtocol?
    var sel: Selector?
    var lgTimer: Timer? = nil
    
    override init() {
        super.init()
    }
    
    func lg_scheduledTimer(timeInterval ti: TimeInterval, target aTarget: Any, selector aSelector: Selector, userInfo: Any?, repeats yesOrNo: Bool){
        self.lgTimer = Timer.init(timeInterval: ti, target: self, selector: aSelector, userInfo: userInfo, repeats: yesOrNo)
        RunLoop.current.add(self.lgTimer!, forMode: .common)
        
        self.target = aTarget as? NSObjectProtocol
        self.sel    = aSelector
        
        guard self.target?.responds(to: self.sel) == true else{
            return
        }
        
        let method = class_getInstanceMethod(self.classForCoder, #selector(lgTimerFire))
        class_replaceMethod(self.classForCoder, self.sel!, method_getImplementation(method!), method_getTypeEncoding(method!))
    }
    
    
    @objc fileprivate func lgTimerFire(){
        if self.target != nil{
            self.target!.perform(self.sel)
        }
        else{
            self.lgTimer?.invalidate()
            self.lgTimer = nil
        }
    }
  
    override func forwardingTarget(for aSelector: Selector!) -> Any? {
        if self.target?.responds(to: self.sel) == true {
            return self.target
        }
        else{
            print("心里没有点数,写这样的代码,还要我给你填坑")
            return super.forwardingTarget(for: aSelector)
        }        
    }
    
    deinit {
        print("\(self) 走了")
    }
    
}

相关文章

  • RxSwift-中介者模式

    函数响应编程&RxSwift核心逻辑 上函数响应编程&RxSwift核心逻辑 下待续...正在努力编写RxSwif...

  • RxSwift-中介者模式

    强引用问题 OC版 1、方法一 didMoveToParentViewController 2、方法二 block...

  • RxSwift-中介者模式

    中介者模式,顾名思义,通过中介来连接买家和供应商,减少买家和供应商的联系成本。在RxSwift中存在很多中介者来帮...

  • RxSwift-中介者模式(Timer)

    中介者顾名思义就是一个桥梁,通过中介者使对象间解耦。首先看一下定时器Timer循环引用问题无法释放,下面的代码: ...

  • RxSwift-中介者模式&deallocating

    我们先由timer的创建使用,引出中介者模式,进而扩展介绍Rxswift的中介者模式使用。 首先,我们来看time...

  • iOS设计模式--中介者模式

    iOS设计模式--中介者模式 iOS设计模式--中介者模式

  • 第5章 -行为型模式-中介者模式

    一、中介者模式的简介 二、中介者模式的优缺点 三、中介者模式的实例

  • 中介者模式(Mediator Pattern)

    中介者模式:使用中介者模式来集中相关对象之间复杂的沟通和控制方式。 中介者模式是行为型模式之一。这里中介者模式的定...

  • 中介者模式

    一、中介者模式介绍 二、中介者模式代码实例

  • 中介者模式(Mediator)

    中介者模式的定义 中介者模式(Mediator Pattern)又称为调解者模式或者调停者模式。用一个中介对象封装...

网友评论

      本文标题:RxSwift-中介者模式

      本文链接:https://www.haomeiwen.com/subject/qgoidctx.html