应用程序在访问主运行循环时崩溃 (SIGABRT)


AppXYZ(2111,0xb04a3000) malloc: *** mach_vm_map(size=1207959552) failed (error code=3)
*** error: can't allocate region
*** set a breakpoint in malloc_error_break to debug
libc++abi.dylib: terminating with uncaught exception of type std::bad_alloc: std::bad_alloc

如何从上面的调试器日志中获取符号化信息?

就像我需要知道地址的类(0xb04a3000),代码中错误的确切位置等等。

在 gdb 中,我会按照它所说的去做,即在提到的函数中放置一个断点:

$ gdb AppXYZ
[... gdb starts ...]
gdb$ break malloc_error_break
gdb$ run

重现导致崩溃的东西。非正式地说,这似乎是因为它试图在单个malloc()调用中分配超过 1 GB 的内存,这在某些环境中相当大胆。

从你的帖子中,我会说你用完了内存。

Malloc was not able to allocate the requested memory

这是因为您必须请求使用 malloc 分配大量内存。

我建议您减少要分配的内存量并尝试。

有关更多详细信息,请参阅 Malloc 错误代码 = 3 和 Malloc 错误

最新更新