• 设为首页
  • 点击收藏
  • 手机版
    手机扫一扫访问
    迪恩网络手机版
  • 关注官方公众号
    微信扫一扫关注
    迪恩网络公众号

ios - LLDB 命令用于查看特定内存地址处的人类可读值

[复制链接]
菜鸟教程小白 发表于 2022-12-13 10:49:14 | 显示全部楼层 |阅读模式 打印 上一主题 下一主题

我在我的 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:] 

我对 SO 社区的问题是:

是否可以使用 LLDB 调试控制台查看特定内存地址处的人类可读数据

例如,显示如下的值:

(self=0x18109890, _cmd=0x31facc39, object=0x18138b90)

我可以打印出这些值以便查看这些内存地址的数据吗?

例如:如果我在内存中有以下值:

// NSString @ memory address: 0x123456
NSString *example = @"exampleString"; 

我可以使用什么 LLDB 命令来查看内存地址 0x123456exampleString 的人类可读值?

根据其他人的建议(感谢 Jim Ingham )和各种互联网搜索,我尝试了以下命令:

  • (lldb) expr *((MyObjectType *) 0x123456)
  • (lldb) 帧变量 *object
  • 内存读取-s1 -fu -c10000 0x123456 --force

还有一些其他的,但所有这些都给了我更多的内存地址,或者不是人类可读的内存转储。我希望做的是读取或打印出将流经我的程序的实际值,以查看可能出现问题的一些线索。

更新

我终于能够根据到目前为止在这篇文章中收到的建议打印这些值。我获得更多神秘内存地址的原因是因为我试图评估预编译的二进制文件。当我针对我自己的项目代码运行建议的命令时,一切正常。



Best Answer-推荐答案


当然。如果您想要原始内存转储,请尝试 memory read 命令。如果你有对象类型的调试信息,你可以将它传递给 -t 选项到 memory read (这对于对象数组更有用。)

或者您可以使用表达式解析器,例如:

(lldb) expr ((MyObjectType *) 0x18138b90)

如果你在带有调试信息的框架中,你也可以使用 frame variable 来查看局部变量和参数。比如:

(lldb) frame variable *object

应该显示object的内容。

关于ios - LLDB 命令用于查看特定内存地址处的人类可读值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32555447/

回复

使用道具 举报

懒得打字嘛,点击右侧快捷回复 【右侧内容,后台自定义】
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

关注0

粉丝2

帖子830918

发布主题
阅读排行 更多
广告位

扫描微信二维码

查看手机版网站

随时了解更新最新资讯

139-2527-9053

在线客服(服务时间 9:00~18:00)

在线QQ客服
地址:深圳市南山区西丽大学城创智工业园
电邮:jeky_zhao#qq.com
移动电话:139-2527-9053

Powered by 互联科技 X3.4© 2001-2213 极客世界.|Sitemap