new[]分配的内存大小

Size of memory allocated by new[]

本文关键字:内存 分配 new      更新时间:2023-10-16

我正在调查一个崩溃,我在

下面有堆栈跟踪
...
12 4292e2c4 73148e89 KERNELBASE!RaiseException+0x58
13 4292e2fc 73150e7c MSVCR80!_CxxThrowException+0x46 [f:ddvctoolscrt_bldself_x86crtprebuildehthrow.cpp @ 161]
14 4292e318 386f21ba MSVCR80!operator new+0x69 [f:ddvctoolscrt_bldself_x86crtsrcnew.cpp @ 63]
15 4292e32c 386f1f39 StatEngineProxy!std::allocator<myClass>::allocate+0x1a [c:program files (x86)microsoft visual studio 8vcincludexmemory @ 146]
16 4292e384 386ef7e8 myModule!std::vector<myClass,std::allocator<myClass> >::_Insert_n+0xf9 [c:program files (x86)microsoft visual studio 8vcincludevector @ 1138]
17 4292e3b0 386ec20f myModule!std::vector<myClass,std::allocator<myClass> >::insert+0x88 [c:program files (x86)microsoft visual studio 8vcincludevector @ 855]
18 4292e3dc 3872bb17 myModule!std::vector<myClass,std::allocator<myClass> >::push_back+0xaf [c:program files (x86)microsoft visual studio 8vcincludevector @ 800]
....

原因很简单:bad_alloc。问题是我如何才能找到多少内存仍然试图分配。

try...catch添加到该类中的所有新[]中,然后在catch子句中设置详细的调试信息

您可以给STL一个自定义分配器,这样它的所有内存请求都将通过您提供的函数。

这里有一个例子:http://www.sjbrown.co.uk/2004/05/01/pooled-allocators-for-the-stl/

很简单。你得到了CRT的光源。(可能在C:Program FilesMicrosoft Visual Studio 10.0VCcrtsrcnew.cpp)。因此,您可以查看第14帧的源代码和变量

您会发现第58行看起来像void *__CRTDECL operator new(size_t size) _THROW1(_STD bad_alloc)。参数size就是你要找的