swift 定时器. scheduled定时器未启动

2fjabf4q  于 2023-01-12  发布在  Swift
关注(0)|答案(3)|浏览(230)

我正在尝试计算车辆通过两个检查站所需的时间。我设置了以下计时器来实现这一点。

func startTimer() {
    if hasStarted == true && timerStarted == false {
        print("Timing started!")
        gameTimer = Timer.scheduledTimer(timeInterval: 0.001, target: self, selector: (#selector(activeTiming)), userInfo: nil, repeats: true)
        timerStarted = true
    }
}

@objc func activeTiming() {
    print("Active timing block")
    if(hasFinished == false) {
        gameTime = gameTime + 0.001
        print("Add time succeeded")
    } else {
        gameTimer?.invalidate()
    }
}

预期产出如下:

Timing started!
Active timing block
Add time succeeded
Add time succeeded ... etc

实际输出:

Timing started!

因此,似乎startTimer被正确调用,但计时器没有触发activeTiming代码块。任何建议都将非常有帮助。提前感谢您的帮助。

u59ebvdq

u59ebvdq1#

发布这段代码,因为它是我正在使用的,但我不是Maven斯威夫特,所以你的里程可能会有所不同!

class PerformanceTest {
    var name:           String = ""
    var tolerance:      Int64 = 0
    var lastTime:       Int64 = 0
    var thisTime:       Int64 = 0
    var delta:          Int64 = 0
    var percent:        Float = 0

    func setTolerance(vName: String, vTolerance: Int64) {
        name = vName
        tolerance = vTolerance
    }

    func reset() {
        delta = 0
        percent = Float((Float(delta) / Float(tolerance))) * 100
        //high = 0
    }

    func start() {
        lastTime = Date().toMillis()
    }

    func finish() {
        thisTime = Date().toMillis()
        let vDelta = thisTime - lastTime
        if(vDelta > delta) {
            delta = vDelta
            percent = Float((Float(delta) / Float(tolerance))) * 100
            if(delta > tolerance) {
                print("Performance Indicator: \(name) Above Tolerance" + String(format: "%3.0f", percent) + "%")
            }
        }
    }

    func display() -> String {
        //high = delta
        //print("\(vString) Tolerance: \(tolerance) Max: \(high)")
        return String(format: "%3.0f", percent) + "%  |"
    }
   }

extension Date {
    func toMillis() -> Int64! {
        return Int64(self.timeIntervalSince1970 * 1000)
    }

用法:

var performanceDefenseLoop = PerformanceTest()
performanceDefenseLoop.setTolerance(vName:  "DefenseLoop", vTolerance: 150)

func timeToUpdateDefenses()
{
    performanceDefenseLoop.start()
    defesensesLoop()
    performanceDefenseLoop.finish()
    print("\(performanceDefenseLoop.Display())"
}

//重置性能DefenseLoop. reset()

    • 确保在主线程中启动计时器!**
ctzwtxfj

ctzwtxfj2#

您的代码对我来说是有效的,但这并不是您希望对事件计时的方式,因为Timer不是那么精确,而且您浪费了大量的计算时间(读取电池)。
相反,我建议采取以下做法:
事件开始时,记录开始时间:

let startTime = Date()

事件结束时,计算经过的时间:

let elapsedTime = Date().timeIntervalSince(startTime)

elapsedTime将以秒为单位(包括小数秒)。

u0sqgete

u0sqgete3#

我也遇到过一个类似的问题,即定时器主体没有被调用。我发现定时器是从后台线程而不是主线程调度的。将它 Package 在DispatchQueue.main.async中可以解决这个问题。

DispatchQueue.main.async {
    self.pingTimer = Timer.scheduledTimer(withTimeInterval: timerInterval, repeats: true, block: { [weak self] timer in
        //
        Logger.shared.log(.anyCable, .debug, "timer run")
        self?.sendPing(sender: self)
    })
}

相关问题