用于查看特定内存地址处人类可读值的 LLDB 命令
LLDB command to view human-readable values at specific memory addresses
我 运行 在我的 iOS 应用程序中遇到了一个错误,并且 Stack Trace 并不是特别有启发性。当我在 (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:]
我对 SO 社区的问题是:
是否可以使用 LLDB 调试控制台查看特定内存地址的人类可读数据?
例如,显示如下的值:
(self=0x18109890, _cmd=0x31facc39, object=0x18138b90)
我可以打印出这些值以便查看这些内存地址的数据吗?
例如:如果我在内存中有以下值:
// NSString @ memory address: 0x123456
NSString *example = @"exampleString";
我可以使用什么 LLDB 命令来查看内存地址 0x123456
处 exampleString
的人类可读值?
根据其他人的建议(感谢Jim Ingham)和各种互联网搜索,我尝试了以下命令:
(lldb) expr *((MyObjectType *) 0x123456)
(lldb) frame variable *object
memory read -s1 -fu -c10000 0x123456 --force
和其他一些,但所有这些给我的是更多的内存地址,或者是人类不可读的内存转储。我希望做的是读取或打印出本应流经我的程序的实际值,以查看有关可能出现问题的一些线索。
更新
到目前为止,我终于能够根据在此 post 中收到的建议打印这些值。我得到更多神秘内存地址的原因是因为我试图评估预编译的二进制文件。当我 运行 针对我自己的项目代码建议的命令时,一切正常。
当然可以。如果您想要原始内存转储,请尝试 memory read
命令。如果你有对象类型的调试信息,你可以将它传递给 -t
选项到 memory read
(这对对象数组更有用。)
或者您可以使用表达式解析器,例如:
(lldb) expr ((MyObjectType *) 0x18138b90)
如果您在带有调试信息的框架中,您还可以使用 frame variable
查看局部变量和参数。例如:
(lldb) frame variable *object
应该向您显示 object
的内容。
我 运行 在我的 iOS 应用程序中遇到了一个错误,并且 Stack Trace 并不是特别有启发性。当我在 (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:]
我对 SO 社区的问题是:
是否可以使用 LLDB 调试控制台查看特定内存地址的人类可读数据?
例如,显示如下的值:
(self=0x18109890, _cmd=0x31facc39, object=0x18138b90)
我可以打印出这些值以便查看这些内存地址的数据吗?
例如:如果我在内存中有以下值:
// NSString @ memory address: 0x123456
NSString *example = @"exampleString";
我可以使用什么 LLDB 命令来查看内存地址 0x123456
处 exampleString
的人类可读值?
根据其他人的建议(感谢Jim Ingham)和各种互联网搜索,我尝试了以下命令:
(lldb) expr *((MyObjectType *) 0x123456)
(lldb) frame variable *object
memory read -s1 -fu -c10000 0x123456 --force
和其他一些,但所有这些给我的是更多的内存地址,或者是人类不可读的内存转储。我希望做的是读取或打印出本应流经我的程序的实际值,以查看有关可能出现问题的一些线索。
更新
到目前为止,我终于能够根据在此 post 中收到的建议打印这些值。我得到更多神秘内存地址的原因是因为我试图评估预编译的二进制文件。当我 运行 针对我自己的项目代码建议的命令时,一切正常。
当然可以。如果您想要原始内存转储,请尝试 memory read
命令。如果你有对象类型的调试信息,你可以将它传递给 -t
选项到 memory read
(这对对象数组更有用。)
或者您可以使用表达式解析器,例如:
(lldb) expr ((MyObjectType *) 0x18138b90)
如果您在带有调试信息的框架中,您还可以使用 frame variable
查看局部变量和参数。例如:
(lldb) frame variable *object
应该向您显示 object
的内容。