出于某种原因,当我单步执行Swift代码时,LLDB没有向我显示变量的内容.实际执行工作正常,但无论我尝试什么,我都看不到我的字符串的内容!
这是我在变量列表中看到的内容:

此时type包含"名称"并value包含"Logan".但你不能告诉我们在这看.如果我使用"快速查看"按钮,则表示值为"(无)".
当我po从控制台尝试使用String 时,我得到了这种乱码:
(lldb) po space
error: <REPL>:1:1: error: non-nominal type '$__lldb_context' cannot be extended
extension $__lldb_context {
^
<REPL>:11:5: error: 'Space.Type' does not have a member named '$__lldb_wrapped_expr_0'
$__lldb_injected_self.$__lldb_wrapped_expr_0(
^
Run Code Online (Sandbox Code Playgroud)
但是这会有所不同 有时我会得到类似的东西:
class name = __NSAtom
Run Code Online (Sandbox Code Playgroud)
要么
Printing description of [0]:
(String) [0] = {
core = {
_baseAddress = Builtin.RawPointer = 0x00000001004016f0
_countAndFlags = -4611686018427387894
_owner = Some {
Some = (instance_type = Builtin.RawPointer = 0x0000000100401820 -> 0x00007fff7b3d5390 (void *)0x00007fff7b3d5340: __NSCFString)
}
}
}
Run Code Online (Sandbox Code Playgroud)
要么
Printing description of declaration:
(String) declaration = <DW_OP_piece for offset 8: top of stack is not a piece>
Run Code Online (Sandbox Code Playgroud)
...但绝不是字符串的实际内容!
更新:
我注意到问题似乎只是componentsSeparatedByString()在函数调用后才开始发生.(这发生在顶部,所以当我踩到时,我没有注意到调试器实际上确实显示了值,直到这一点.)所以这个函数发生了奇怪的事情.我已更新问题标题以反映这些新信息.
有趣的是,似乎一旦字符串被这个调用"破坏",你就无法在其他任何地方查看它,即使传递给另一个函数.并且任何常规字符串变量都不可见.肯定是一个错误,但我想知道是否有一个解决方法.调试程序真的很难!
当我遇到这个问题时,我要么NSLog("\(myThing)")在我想要调试的编译代码中使用,要么expression NSLog("\(myThing)")在调试器的 REPL 中调用
| 归档时间: |
|
| 查看次数: |
4978 次 |
| 最近记录: |