观察属性崩溃仪器(泄漏配置文件)Xcode 9.3(Swift 4.1)

时间:2018-04-09 09:05:01

标签: ios swift observable xcode-instruments xcode9.3

当我运行以下代码(一个简化示例,为演示崩溃而创建)时,它会在我选择Run时按预期执行(两个os_log消息都在Console中打印)。

然而,当我在Memory Debug Navigator中打开它时 - 按下Restart - 它崩溃了(只有第一个os_log消息在Console中打印)。

坠机发生在观察(...)。

import os
import UIKit

class ObserverCrashingExample: NSObject {

    @objc private var animation: UIViewPropertyAnimator?
    private var observer: NSKeyValueObservation?

    override init() {

        super.init()

        animation = UIViewPropertyAnimator( duration: 1, curve: .linear, animations: { })

        animation!.pauseAnimation()

        os_log("X_AMPLE Executes")

        observer = animation!.observe(\.isRunning, options: [.new, .old]) { _ , _ in }

        os_log("X_AMPLE Does not execute")

    }

    required init?(coder aDecoder: NSCoder) { fatalError("init(coder:) has not been implemented") }

}

我正在运行Xcode 9.3,Swift 4.1,iOS 11.3部署目标。

有什么想法吗?这是编译器问题吗?

干杯

1 个答案:

答案 0 :(得分:0)

我尝试了三个单词:

  1. 禁用“记录参考计数”。这阻止了它崩溃。但是仪器显示出比平常更多的泄漏,这使得找不到真正的泄漏。
  2. 评论我所有的KVO电话。在我的情况下不起作用。
  3. 将我的代码降级为Swift 4.0。我重新安装了Xcode 9.2,现在可以使用了。