[bind] counterintuitive behavior with vector and auto_ptr
data:image/s3,"s3://crabby-images/bdc6d/bdc6d58d359cc9389a17fab9e95d2f2f1c70fdd4" alt=""
Hi there, I'm doing some job interview preparations. Always a good
idea to go back to the basics and tinker around a bit. I came across a
surprising behavior when using std::vector, std::auto_ptr, and
boost::bind.
Basically, I have a vector of auto_ptrs which is copied into a second
vector, thus the first vector's auto_ptr loss their resource and point
to nowhere. Basic stuff, as I said. Now, when I try to use an auto_ptr
from the first vector using boost::bind everything still works.
Meaning the code doesn't fail, although it should. I find that
surprising. Why is boost::bind recreating the resource?
Here is a my example code:
#include <algorithm>
#include <iostream>
#include <vector>
#include
data:image/s3,"s3://crabby-images/48064/48064d72b0cc2a7ace5789b3da09cb4b9f086523" alt=""
AMDG Christian Henning wrote:
Hi there, I'm doing some job interview preparations. Always a good idea to go back to the basics and tinker around a bit. I came across a surprising behavior when using std::vector, std::auto_ptr, and boost::bind.
auto_ptr and vector don't mix. Use unique_ptr instead.
Basically, I have a vector of auto_ptrs which is copied into a second vector, thus the first vector's auto_ptr loss their resource and point to nowhere. Basic stuff, as I said. Now, when I try to use an auto_ptr from the first vector using boost::bind everything still works. Meaning the code doesn't fail, although it should. I find that surprising. Why is boost::bind recreating the resource?
It isn't. Boost.Bind passes the arguments by reference, so the auto_ptr is never copied. In Christ, Steven Watanabe
data:image/s3,"s3://crabby-images/bdc6d/bdc6d58d359cc9389a17fab9e95d2f2f1c70fdd4" alt=""
Hi there,
Basically, I have a vector of auto_ptrs which is copied into a second vector, thus the first vector's auto_ptr loss their resource and point to nowhere. Basic stuff, as I said. Now, when I try to use an auto_ptr from the first vector using boost::bind everything still works. Meaning the code doesn't fail, although it should. I find that surprising. Why is boost::bind recreating the resource?
It isn't. Boost.Bind passes the arguments by reference, so the auto_ptr is never copied.
All auto_ptrs have been copied a couple of lines before. See the std::copy call. After that my debugger tells me that all auto_ptrs are empty which makes sense. Still not clear to me what exactly happens when using bind. Christian
data:image/s3,"s3://crabby-images/0212c/0212cd561494694fb513cfe9ac52af4d3e5e2f42" alt=""
Hi, the reason why the for_each loop works, boost::bind unwraps the auto_ptr with get(), and get() does not trigger a debug break, but the operator -> does, so your other calls trigger a breakpoint (on release build this will be disabled and all test will pass). And the boost bind call of A::foo does not crash, because it does not touches 'this' of the object (the bind call uses the static address of A::foo and not the vtable of A). TJ. Am 12.06.2010, 08:41 Uhr, hast Du in gmane.comp.lib.boost.user geschrieben:
Hi there,
<---Schnitt--->
It isn't. Boost.Bind passes the arguments by reference, so the auto_ptr is never copied.
All auto_ptrs have been copied a couple of lines before. See the std::copy call. After that my debugger tells me that all auto_ptrs are empty which makes sense. Still not clear to me what exactly happens when using bind.
Christian
data:image/s3,"s3://crabby-images/bdc6d/bdc6d58d359cc9389a17fab9e95d2f2f1c70fdd4" alt=""
Thanks all. I can now see that the auto_ptr::get() doesn't throw but
auto_ptr::operator->() does, although it's labeled as throw(). It only
throws in debug mode, anyway.
Thanks again,
Christian
On Fri, Jun 11, 2010 at 11:12 PM,
Hi,
the reason why the for_each loop works, boost::bind unwraps the auto_ptr with get(), and get() does not trigger a debug break, but the operator -> does, so your other calls trigger a breakpoint (on release build this will be disabled and all test will pass). And the boost bind call of A::foo does not crash, because it does not touches 'this' of the object (the bind call uses the static address of A::foo and not the vtable of A).
TJ.
Am 12.06.2010, 08:41 Uhr, hast Du in gmane.comp.lib.boost.user geschrieben:
Hi there,
<---Schnitt--->
It isn't. Boost.Bind passes the arguments by reference, so the auto_ptr is never copied.
All auto_ptrs have been copied a couple of lines before. See the std::copy call. After that my debugger tells me that all auto_ptrs are empty which makes sense. Still not clear to me what exactly happens when using bind.
Christian
_______________________________________________ Boost-users mailing list Boost-users@lists.boost.org http://lists.boost.org/mailman/listinfo.cgi/boost-users
data:image/s3,"s3://crabby-images/9ad60/9ad60a4d1f52e43cc8e1c6cdc198dca641b34916" alt=""
Christian Henning wrote:
All auto_ptrs have been copied a couple of lines before. See the std::copy call. After that my debugger tells me that all auto_ptrs are empty which makes sense. Still not clear to me what exactly happens when using bind.
bind does the equivalent of p.get()->foo(). This doesn't call auto_ptr::operator->, whereas your two other examples do. So maybe VC10 has a get() != 0 assertion inside its op->.
data:image/s3,"s3://crabby-images/60deb/60deb4d6c10efe00852105496c6edad7a74d2fec" alt=""
On Fri, Jun 11, 2010 at 10:41 PM, Christian Henning
// this doesn't fail for_each( v.begin(), v.end(), boost::bind( &A::foo, _1 ));
Could it be that A::foo is called with null this, but since it doesn't use this it doesn't crash? Emil Dotchevski Reverge Studios, Inc. http://www.revergestudios.com/reblog/index.php?n=ReCode
participants (5)
-
Christian Henning
-
Emil Dotchevski
-
Peter Dimov
-
Steven Watanabe
-
Tiemo.Jung@mni.fh-giessen.de