33

我想用MallocStackLogging. 该错误涉及陀螺仪,因此我必须在设备而不是模拟器上进行调试。

我已经设置了MallocStackLogging环境变量并且 iPhone 正确记录了 mallock 堆栈日志:

MyApp(1856) malloc: recording malloc stacks to disk using standard recorder
MyApp(1856) malloc: stack logs being written into /private/var/mobile/Applications/1FD1F8D2-5D30-4AA7-B426-C52FE20266DE/tmp/stack-logs.1856.MyApp.index
MyApp(1856) malloc: Please issue: cp /private/var/mobile/Applications/1FD1F8D2-5D30-4AA7- B426-C52FE20266DE/tmp/stack-logs.1856.MyApp.e8z3IL.link /tmp/

现在我该如何与他们合作?

我可以使用 Xcode Organizer 将它们传输到 Mac。但是我应该如何处理这两个文件呢?

  • 堆栈日志.1856.MyApp.index
  • 堆栈日志.1856.MyApp.e8z3IL.link

我尝试在 Mac 上移动 /tmp 中的文件并调用:

$ malloc_history 1856 -all_events
malloc_history cannot examine process 1856 because the process does not exist.

显然,该malloc_history命令在本地机器上查找正在运行的进程。我缺少手动指定日志文件的选项。

有没有办法让它在(非越狱)设备上直接使用 Xcode 或在将日志传输到 Mac 之后工作?

4

3 回答 3

5

这是我在 idevice 上使用 malloc 堆栈历史调试 APP 的方法,这确实很复杂,但我没有其他方法来处理自动释放池内存问题。

  1. 你需要一个安装了开发工具的越狱设备,然后你就有了 gdb。

  2. 要启用 malloc 堆栈登录,您需要设置环境变量 MallocStackLoggingNoCompact 和 MallocStackLogging,我们需要一些技巧来做到这一点。

首先,我们需要授予您的应用 root 权限。

 mv -f /User/Application/xxxxxxxxxxxxx/YOUR_APP.app /Application/YOUR_APP.app
 cd /Application
 chown -R root:wheel YOUR_APP.app
 chmod 4755 YOUR_APP.app/YOUR_APP

重命名您的程序

mv YOUR_APP.app/YOUR_APP   YOUR_APP.app/BACK_UP_NAME

使用一个简短的 shell 脚本来启动你的程序,这样我们就可以保留环境。将其保存到 YOUR_APP.app/YOUR_APP

#!/bin/bash
export MallocStackLogging=1
export MallocStackLoggingNoCompact=1

exec /Applications/YOUR_APP.app/BACK_UP_NAME

完毕。

只需启动您的应用程序,触摸图标或使用打开命令,您将在 /tmp 目录中看到堆栈日志文件。

使用ps aux | grep YOUR_APPfind process id,gdb -p PROCESS_ID附加到进度,下断点,try info malloc ADDRESS,malloc 历史将显示。

于 2014-03-05T11:39:49.020 回答
2

在 Instruments 应用程序中,可以诊断在模拟器或设备上运行的应用程序,Allocations 工具记录内存地址和分配历史。您可以按对象/分配类型或特定内存地址进行浏览。这可能是实现您想要的最直接的方法。

在设备上运行 malloc_history 需要越狱以启用与设备的 ssh 连接,或者从您的代码中运行 malloc_history。但我不确定 malloc_history 是否存在于 iOS 设备上。而且 malloc_history 的帮助文本没有提到操作日志文件的选项,而不是您可能已经知道的现有进程。

于 2013-09-16T18:56:01.557 回答
-5

我并不是说听起来轻率,但是您是否尝试过将设备插入并在连接时在调试器下运行它?

我在设备上运行应用程序时进行了大量调试。您确实需要在调试器下启动应用程序。

于 2011-03-14T09:44:24.483 回答