|
Boost : |
From: Dirk Griffioen (d.griffioen_at_[hidden])
Date: 2004-07-13 06:31:03
Thanks Jeff,
Your solution works - with a little twist:
I took the solution from #20 (thanks Robert!) and now it loooks like:
if(NULL != t.pi_)
t.pi_->add_ref_copy();
I also outcommented line 125.
& now my app works fine!
We will, however, upgrade to #20 as soon as possible.
Regarding the little discussion: it might very well be the case that
uses find the library very usefull, without too many a problem. We
certainly do, for instance on windows 2k (vc71) and HP True64 (probably
gcc but I'm not sure).
We have a lot of platforms here (HP, AIX, SUN, VMS, AS400 and Mainframe
- with different versions of native compilers and/or gcc) and it is
likely we will port to those platforms. If there's an interest, it might
be possible to gather some figures.
Cheers, Dirk
-----Original Message-----
From: boost-bounces_at_[hidden]
[mailto:boost-bounces_at_[hidden]] On Behalf Of Jeff Flinn
Sent: maandag 12 juli 2004 17:07
To: boost_at_[hidden]
Subject: [boost] Re: "memory access violation" in boost::serialization
"Dirk Griffioen" <d.griffioen_at_[hidden]> wrote in message
news:2505062E579A9B45888B70D9BCFB3C073BA8BD_at_ex03.hidomain...
> Hi,
>
> I encountered the following little problem:
>
> I would like to use the following datastructures with
boost::serialize:
>
> struct Match {};
> typedef std::string Key;
> typedef tst< Match, Key > TernarySearchTree; //this one has a
shared_ptr
>
> typedef std::vector< TernarySearchTree > Trees;
> typedef std::map< std::string, Trees > Symbols;
>
> I have defined some serialize overloads so saving goes fine, but when
> loading I get a "memory acces violation" inside the following code:
>
> {
> boost::archive::text_iarchive ia(ifs);
> ia >> symbols_;
> }
>
> More specific, inside <boost/serializiton/shared_count.hpp>
>
> void add_ref_copy()
> {
> #if defined(BOOST_HAS_THREADS)
> mutex_type::scoped_lock lock(mtx_);
> #endif
> ++use_count_;
> }
>
> Which constructs a scoped_lock, and there, the "explicit
> scoped_lock(lightweight_mutex & m): m_(m)" seems to go wrong.
Actually you'll find that the this pointer is either NULL or invalid.
>
> What could be the reason? The more since all worked fine (saving and
> loading) when I used a simple vector of tst's.
The following changes to .../boost/serialization/shared_ptr.hpp should
do
it:
change line 74: if(t) t->add_ref_copy();
and
comment out line 125: // shared_ptr_access::weak_count(*t) = 0;
IIRC, line 125 is the primary culprit.
-----------------
Jeff Flinn
Applied Dynamics, International
_______________________________________________
Unsubscribe & other changes:
http://lists.boost.org/mailman/listinfo.cgi/boost
Boost list run by bdawes at acm.org, gregod at cs.rpi.edu, cpdaniel at pacbell.net, john at johnmaddock.co.uk