RE: [Boost-users] Scoped_ptr + deleter
data:image/s3,"s3://crabby-images/8221a/8221a36129f96816e9585c1cfc3f4c2ab0242516" alt=""
-----Original Message----- From: boost-users-bounces@lists.boost.org [mailto:boost-users-bounces@lists.boost.org] On Behalf Of Caleb Epstein Sent: Monday, May 23, 2005 2:32 PM To: boost-users@lists.boost.org Subject: Re: [Boost-users] Scoped_ptr + deleter
Why doesn't scoped_ptr have an additional template
On 5/23/05, Sohail Somani
wrote: parameter to accept a deleter?
Because that would make it larger than sizeof (T*). I believe the general consensus on this is to use shared_ptr or perhaps the upcoming policy_ptr.
For educational purposes, why is this important?
data:image/s3,"s3://crabby-images/6e75b/6e75bb6d86d221a7de0693e21d773e896dfc9e3e" alt=""
On 5/23/05, Sohail Somani
-----Original Message----- Because that would make it larger than sizeof (T*). I believe the general consensus on this is to use shared_ptr or perhaps the upcoming policy_ptr.
For educational purposes, why is this important?
I'm not certain, but I would guess that overhead is the reason. Perhaps someone more closely involved in the implementation (Peter?) would care to comment. The "bells and whistles" all went into shared_ptr. Unless you're trying to eke out every last CPU cycle from your code, using shared_ptr as a scoped_ptr w/deleter is an eminently reasonable design choice -- Caleb Epstein caleb dot epstein at gmail dot com
data:image/s3,"s3://crabby-images/ad0c2/ad0c2dfe651d02ddd8ffd1073d3ff358cff57296" alt=""
On May 23, 2005, at 6:13 PM, Caleb Epstein wrote:
On 5/23/05, Sohail Somani
wrote: -----Original Message----- Because that would make it larger than sizeof (T*). I believe the general consensus on this is to use shared_ptr or perhaps the upcoming policy_ptr.
For educational purposes, why is this important?
I'm not certain, but I would guess that overhead is the reason. Perhaps someone more closely involved in the implementation (Peter?) would care to comment.
The "bells and whistles" all went into shared_ptr. Unless you're trying to eke out every last CPU cycle from your code, using shared_ptr as a scoped_ptr w/deleter is an eminently reasonable design choice
A customized deleter does not have to occupy space if it has no data
members. boost::compressed_pair can easily be used to optimize away
space for an empty member, e.g.:
compressed_pair
data:image/s3,"s3://crabby-images/b27e9/b27e9e33c86b5c577e90a6b3fa113e882541e0ca" alt=""
Caleb Epstein wrote:
I'm not certain, but I would guess that overhead is the reason. Perhaps someone more closely involved in the implementation (Peter?) would care to comment.
As a user of scoped_ptr and scoped_array, I expressed a strong opinion that its memory usage remain as is, and some Boost developers agreed. If you have a way to maintain the current behavior (speed and memory footprint) as a default, you are welcome to add functionality. Otherwise, it becomes useless to me. -- Dick Hadsell 914-259-6320 Fax: 914-259-6499 Reply-to: hadsell@blueskystudios.com Blue Sky Studios http://www.blueskystudios.com 44 South Broadway, White Plains, NY 10601
data:image/s3,"s3://crabby-images/6e75b/6e75bb6d86d221a7de0693e21d773e896dfc9e3e" alt=""
On 5/24/05, Richard Hadsell
As a user of scoped_ptr and scoped_array, I expressed a strong opinion that its memory usage remain as is, and some Boost developers agreed. If you have a way to maintain the current behavior (speed and memory footprint) as a default, you are welcome to add functionality. Otherwise, it becomes useless to me.
I'm not suggesting any changes be made to scoped_ptr, and from the replies of others it sounds like move_ptr is way forward on this. -- Caleb Epstein caleb dot epstein at gmail dot com
participants (4)
-
Caleb Epstein
-
Howard Hinnant
-
Richard Hadsell
-
Sohail Somani