实例化的可选变量在Xcode调试器中显示为nil

Dyl*_*lan 7 debugging xcode swift xcode11 swift5.1

自从我升级到Xcode 11和Swift 5.1以来,我遇到了一个奇怪的问题-实例化了一个可选变量后,它在Xcode调试器中仍然显示为nil!

我有一个可选的类变量,称为booking

var booking: Booking?
Run Code Online (Sandbox Code Playgroud)

类型Booking

public struct Booking: Codable {
    var id: Int?
    var start_time: Date?
    var payment_currency: String = "USD"
    var payment_amount: Int?
}
Run Code Online (Sandbox Code Playgroud)

当我单步执行代码时,可以booking在分配代码之前看到它……这太好了:

在此处输入图片说明

然后在分配之后...什么,还是零??:

在此处输入图片说明

我想知道是否以某种方式将其视为惰性变量。但这并不是零,因为可以访问它:

在此处输入图片说明

搜索了一会儿之后,我想知道我在Xcode中的构建模式是否没有设置其“调试可执行文件”标志。但是确实如此。我什至清理并重新构建了该项目,并确定了该标志。

在此处输入图片说明

无论booking是在变量视图中查看还是p booking在控制台视图中输入,它都显示为nil。

这里发生了什么?我需要在升级之前调试的可预测性。

更新

我总结了一种重现此问题的简单方法。首先,创建一个空的单视图项目并将其添加到AppDelegate.swift的顶部:

public struct Booking: Codable {
    var start_time: Date?
    var payment_currency: String = "USD"
}
Run Code Online (Sandbox Code Playgroud)

然后将这些行添加到应用程序(_:didFinishLaunchingWithOptions :) func:

booking = Booking()
print("booking.payment_currency = \(booking?.payment_currency ?? "NULL")")
Run Code Online (Sandbox Code Playgroud)

如之前和在运行时一样设置断点,请注意,即使在分配调试器后,调试器也将预订显示为nil,就像我原来的情况一样。

然后注释掉start_time变量,重新运行,并注意现在调试器显示booking被分配有后的值,正如人们所期望的那样。

因此,看起来像这样的结构中的Date变量(可选或不可选)使调试变得混乱。特别是Date变量-将变量更改为其他类型,例如Int,Int?,String,String?...,没有问题。

除非我缺少非常基本的内容,否则对我来说,这似乎是Xcode调试器中的错误。如果是这样,报告它的最佳方法是在https://developer.apple.com/bug-reporting/吗?

Dyl*_*lan 17

看来我在 Xcode 11 中发现了一个错误。它很容易重现,如上面更新中所述。我已经向 Apple 提交了该错误。

我现在仍在寻找解决方法,因为我使用了很多包含 Date 变量的结构。如果有人能找到,请在下面评论。

  • 可能与这个问题有相同的错误:/sf/ask/4070854301/ 在那个问题中,情况完全不同,但我们再次调试器中显示“nil”,而实际上根本不是“nil”。 (2认同)
  • 在 Xcode 12.3 中仍然发生在我身上。 (2认同)

mat*_*att 14

错误的原因不是var start_time: Date?存在或不存在,而是 Date 是 Swift Foundation 覆盖。如果除去可编码的一致性和做出start_timeNSDate?,一切都很好。很明显 LLDB 被像Date?.

这个链接的问题中,我们看到与URL?. 如果我们将其更改为NSURL?一切都很好。

我并不是说这是一个可行的解决方法!你想要并且需要使用 Swift 类型。我只是说这是搞砸了 LLDB 的原因。您可以在报告错误时包含该信息。

此错误计划在 Xcode 12.5 中修复。

  • 仍然存在于 Xcode 12.2 (12B45b) 中 (2认同)