0

私は持っていThingますThingManager

Thingしばらく誰も特定のことについて言及しない場合は、ThingManager忘れたいと思います。

let manager = ThingManager()
let thing1 = Thing(name: "thing1")
manager.addThing(thing1)
manager.sawSomeThing(named: thing1.name)
print("Manager has this many things: ", manager.things.count)
Timer.scheduledTimer(withTimeInterval: 10.0, repeats: false, block: { (timer) in
    // By now, the manager should have forgotten about the thing
    print("Manager has this many things: ", manager.things.count)
})

ブロックベースのタイマーと RunLoop ベースのタイマーの両方を試しました。彼らは決して「消える」ようには見えません

struct Thing {
    var name: String
}

class ThingManager {
    var things: [String: Thing] = [:]
    fileprivate var thingWatchingRunLoop = RunLoop()
    fileprivate var thingWatchingQueue = DispatchQueue.global(qos: .utility)
    fileprivate var thingWatchingTimers: [String: Timer] = [:]

    func addThing(_ thing: Thing) {
        self.things[thing.name] = thing
    }

    func sawSomeThing(named name: String) {
        self.thingWatchingQueue.async {
            // re-up the timer so we don't forget about that thing
            if let timer = self.thingWatchingTimers[name] {
                timer.invalidate()
            }
            let timer = Timer(timeInterval: 5.0, target: self, selector: #selector(self.timerWentOff(_:)), userInfo: ["name":name], repeats: false)
            self.thingWatchingRunLoop.add(timer, forMode: .commonModes)
            self.thingWatchingTimers[name] = timer
        }
    }

    @objc func timerWentOff(_ timer: Timer) {
        let info = timer.userInfo as! [String: String]
        let name = info["name"]
        self.removeThing(named: name!)
    }

    func removeThing(named name: String) {
        self.things.removeValue(forKey: name)
    }
}

更新、ブロックベースのバージョン: https://gist.github.com/lacyrhoades/f917b971e97fdecf9607669501ef6512

4

2 に答える 2

1

新しい Runloop インスタンスを作成する代わりに、タイマーを現在の runloop に追加するだけでよいと思います。

変化する:

fileprivate var thingWatchingRunLoop = RunLoop()

に:

fileprivate var thingWatchingRunLoop = RunLoop.current

そして、すべてが正しく機能するはずです!

于 2016-11-09T23:17:52.987 に答える