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 错误