Using shared_ptr slightly different
data:image/s3,"s3://crabby-images/4e034/4e0343ca905e83966a4eae2a2b762b0f7737f629" alt=""
Hello,
I want to use the shared_ptr with objects that are allocated using
a factory. The problem is the deallocation. It has to be done with
a ``manager'' class. For example, here is how the allocation and
deallocation has to be done:
PxyFileData& geo_file = dynamic_cast
data:image/s3,"s3://crabby-images/1b90b/1b90bfc05206175c6d3630707d7ef800325812e2" alt=""
"Daniel Lidström"
Hello,
I want to use the shared_ptr with objects that are allocated using a factory. The problem is the deallocation. It has to be done with a ``manager'' class. For example, here is how the allocation and deallocation has to be done:
PxyFileData& geo_file = dynamic_cast
(fileMan.New("geo")); fileMan.Close(geo_file); I would like to be able to put shared_ptr<PxyFileData>'s into a std::vector and then forget about the deallocation. I.e. fileMan.Close(...) should be done automatically when the objects aren't needed anymore. But since the deallocation isn't simply delete, how can I do this?
I believe this should do it:
typedef shared_ptr<void> tPxyFileDataPtr;
typedef ??? tFileMan;
tPxyFileDataPtr PxyFileDataPtr( const char* aName, tFileMan& fileMan )
{
return tPxyFileDataPtr(
dynamic_cast
data:image/s3,"s3://crabby-images/7e462/7e462d7dd00158b0a067f8a3b23a8e5edd2e9dce" alt=""
Daniel Lidström wrote:
Hello,
I want to use the shared_ptr with objects that are allocated using a factory. The problem is the deallocation. It has to be done with a ``manager'' class. For example, here is how the allocation and deallocation has to be done:
PxyFileData& geo_file = dynamic_cast
(fileMan.New("geo")); fileMan.Close(geo_file); I would like to be able to put shared_ptr<PxyFileData>'s into a std::vector and then forget about the deallocation. I.e. fileMan.Close(...) should be done automatically when the objects aren't needed anymore. But since the deallocation isn't simply delete, how can I do this?
I assume that FileMan::Close is void FileMan::Close( FileData& data ); If it took a pointer as an argument, things would be simple: shared_ptr<PxyFileData> p( &geo_file, boost::bind( &FileMan::Close, &fileMan, _1 ) ); But since you need a reference, you'd need to use boost::lambda::bind: namespace ll = boost::lambda; shared_ptr<PxyFileData> p( &geo_file, ll::bind( &FileMan::Close, &fileMan, *ll::_1 ) ); or write your own function object: struct fm_close { typedef void result_type; void operator()( FileMan * pfm, FileData * pfd ) const { pfm->Close( *pfd ); } }; shared_ptr<PxyFileData> p( &geo_file, boost::bind( fm_close(), &fileMan, _1 ) ); or maybe struct fm_close { FileMan * pfm_; explicit fm_close( FileMan * pfm ): pfm_( pfm ) {} void operator()( FileData * pfd ) const { pfm_->Close( *pfd ); } }; shared_ptr<PxyFileData> p( &geo_file, fm_close( &fileMan ) );
data:image/s3,"s3://crabby-images/e5d45/e5d4574f29886ba5f23d813c482c48fe5f4b546b" alt=""
"Daniel Lidström"
Hello,
I want to use the shared_ptr with objects that are allocated using a factory. The problem is the deallocation. It has to be done with a ``manager'' class. For example, here is how the allocation and deallocation has to be done:
PxyFileData& geo_file = dynamic_cast
(fileMan.New("geo")); fileMan.Close(geo_file); I would like to be able to put shared_ptr<PxyFileData>'s into a std::vector and then forget about the deallocation. I.e. fileMan.Close(...) should be done automatically when the objects aren't needed anymore. But since the deallocation isn't simply delete, how can I do this?
Thanks!
-- Daniel SBG AB
If fileMan.Close received pointers, you could do the following:
shared_ptr<PxyFileData> ptr(
&geo_file
, boost::bind(
boost::mem_fn(&
participants (4)
-
Daniel Lidström
-
Jeff Flinn
-
Pablo Aguilar
-
Peter Dimov