data:image/s3,"s3://crabby-images/36f02/36f0244623cd1f52e247defdcee259c8b80286a6" alt=""
On 6 Feb 2011, at 03:00, Michael Xu wrote:
Actually, I put both methods with new and make_shared in there to illustrate the point.
When I run it JUST with new. It completes. When I run it JUST with make_shared it fails.
I'm also running on a x86_64 linux machine with 6 gb of ram.
I asked this on the #boost channel on freenode.net, everyone thought I was confusing stack with heap as well.. but that's not the case... comparing the stack pointers in each frame using "info register' in gdb tells me that the space used by the frames in that stack trace are unreasonably large.
I am not knowledgable about the inner details of boost::shared_ptr, but the problem is that: boost::detail::sp_ms_deleter<test> Is as big as test, and make_shared allocates one of those on the stack, in line: boost::shared_ptr< T > pt( static_cast< T* >( 0 ), detail::sp_ms_deleter< T >() ); Chris