我在iOS应用程序中遇到错误,而堆栈跟踪并不是特别有启发性。当我在(lldb)调试器控制台上运行命令 bt 时,它会吐出一个完整的后跟踪,如下所示:
frame #0: 0x39de23e4 libsystem_c.dylib`__vfprintf + 28
frame #1: 0x39df82c6 libsystem_c.dylib`__v2printf + 374
frame #2: 0x39da723c libsystem_c.dylib`_vsnprintf + 348
frame #3: 0x39da7b2c libsystem_c.dylib`vsnprintf_l + 32
frame #4: 0x39da7b06 libsystem_c.dylib`snprintf_l + 22
frame #5: 0x2f0a19d0 CoreFoundation`__CFStringAppendFormatCore + 8464
frame #6: 0x2f010610 CoreFoundation`_CFStringCreateWithFormatAndArgumentsAux + 76
frame #7: 0x2f9e8162 Foundation`-[NSPlaceholderString initWithFormat:locale:arguments:] + 130
frame #8: 0x2f9e8068 Foundation`+[NSString stringWithFormat:] + 60
* frame #9: 0x002ce4e0 myApp`PFMD5HashFromData(data=0x18109b60) + 412 at PFHash.m:63
frame #10: 0x002d4e42 myApp`-[PFJSONCacheItem initWithObject:](self=0x18109890, _cmd=0x31facc39, object=0x18138b90) + 286 at PFInternalUtils.m:286
frame #11: 0x002d500a myApp`+[PFJSONCacheItem cacheFromObject:](self=0x006e00c8, _cmd=0x0058acb3, object=0x18138b90) + 74 at PFInternalUtils.m:300
frame #12: 0x002e56d8 myApp`-[PFObject(self=0x18151620, _cmd=0x0058bdd1, object=0x18138b90, key=0x0064a2e8) checkForChangesToMutableContainer:forKey:]
是否可以使用LLDB调试控制台查看特定内存地址的人类可读数据?
例如,显示如下的值:
(self=0x18109890, _cmd=0x31facc39, object=0x18138b90)
我可以打印出这些值,以便在这些内存地址中查看数据吗?
例如:如果我在内存中有以下值:
// NSString @ memory address: 0x123456
NSString *example = @"exampleString";
我可以使用哪种LLDB命令在内存地址exampleString
查看0x123456
的人类可读值?
根据其他人的建议(感谢Jim Ingham)和各种互联网搜索,我尝试了以下命令:
(lldb) expr *((MyObjectType *) 0x123456)
(lldb) frame variable *object
memory read -s1 -fu -c10000 0x123456 --force
以及其他几个,但所有这些都给了我更多的内存地址,或者人类不可读的内存转储。我希望做的是读取或打印出我的程序中可能出现的实际值,以查看可能出现问题的一些线索。
到目前为止,我终于可以根据我在这篇文章中收到的建议来打印这些值。我得到更多神秘内存地址的原因是因为我试图评估预先编译的二进制文件。当我针对我自己的项目代码运行建议的命令时,一切正常。
答案 0 :(得分:1)
不确定。如果需要原始内存转储,请尝试memory read
命令。如果您有对象类型的调试信息,则可以将其传递给-t
的{{1}}选项(这对于对象数组更有用。)
或者您可以使用表达式解析器,例如:
memory read
如果您处于调试信息的框架中,您还可以使用(lldb) expr ((MyObjectType *) 0x18138b90)
查看当地人和参数。例如:
frame variable
应该显示(lldb) frame variable *object
。