void copy_constructor() { { boost::interprocess::intrusive_ptr<X, VP> px; boost::interprocess::intrusive_ptr<X, VP> px2(px); BOOST_TEST(px2.get() == px.get()); } { boost::interprocess::intrusive_ptr<Y, VP> py; boost::interprocess::intrusive_ptr<X, VP> px(py); BOOST_TEST(px.get() == py.get()); } { boost::interprocess::intrusive_ptr<X, VP> px(0); boost::interprocess::intrusive_ptr<X, VP> px2(px); BOOST_TEST(px2.get() == px.get()); } { boost::interprocess::intrusive_ptr<Y, VP> py(0); boost::interprocess::intrusive_ptr<X, VP> px(py); BOOST_TEST(px.get() == py.get()); } { boost::interprocess::intrusive_ptr<X, VP> px(0, false); boost::interprocess::intrusive_ptr<X, VP> px2(px); BOOST_TEST(px2.get() == px.get()); } { boost::interprocess::intrusive_ptr<Y, VP> py(0, false); boost::interprocess::intrusive_ptr<X, VP> px(py); BOOST_TEST(px.get() == py.get()); } { boost::interprocess::intrusive_ptr<X, VP> px(new X); boost::interprocess::intrusive_ptr<X, VP> px2(px); BOOST_TEST(px2.get() == px.get()); } { boost::interprocess::intrusive_ptr<Y, VP> py(new Y); boost::interprocess::intrusive_ptr<X, VP> px(py); BOOST_TEST(px.get() == py.get()); } }
void test() { { boost::intrusive_ptr<X> px; test3(px, px); boost::intrusive_ptr<X> px2; test3(px, px2); boost::intrusive_ptr<X> px3(px); test3(px3, px3); test3(px, px3); } { boost::intrusive_ptr<X> px; boost::intrusive_ptr<X> px2(new X); test3(px, px2); test3(px2, px2); boost::intrusive_ptr<X> px3(new X); test3(px2, px3); boost::intrusive_ptr<X> px4(px2); test3(px2, px4); test3(px4, px4); } { boost::intrusive_ptr<X> px(new X); boost::intrusive_ptr<Y> py(new Y); test2(px, py); boost::intrusive_ptr<X> px2(py); test2(px2, py); test3(px, px2); test3(px2, px2); } }
void test() { boost::intrusive_ptr<X> px(new X); BOOST_TEST(px->use_count() == 1); { boost::intrusive_ptr<X> px2(px); BOOST_TEST(px->use_count() == 2); } BOOST_TEST(px->use_count() == 1); }
void move_constructor() { { int prev_addref_release_calls = addref_release_calls; X* x = new X(); boost::interprocess::intrusive_ptr<X, VP> px(x); BOOST_TEST(addref_release_calls == prev_addref_release_calls + 1); //static_assert(std::is_nothrow_move_constructible< boost::interprocess::intrusive_ptr<X, VP> >::value, "test instrusive_ptr is nothrow move constructible"); boost::interprocess::intrusive_ptr<X, VP> px2(boost::move(px)); BOOST_TEST(px2.get() == x); BOOST_TEST(!px.get()); BOOST_TEST(px2->use_count() == 1); BOOST_TEST(addref_release_calls == prev_addref_release_calls + 1); } }
int main() { boost::shared_ptr<X> px( new X ); { boost::shared_ptr<X> px2( px.get(), null_deleter ); BOOST_TEST( px == px2 ); } try { boost::shared_ptr< X > qx = px->shared_from_this(); BOOST_TEST( px == qx ); BOOST_TEST( !( px < qx ) && !( qx < px ) ); } catch( boost::bad_weak_ptr const& ) { BOOST_ERROR( "px->shared_from_this() failed" ); } return boost::report_errors(); }
int main() { boost::weak_ptr<X[]> px2(( boost::shared_ptr<Y[]>() )); }
int main() { boost::weak_ptr<X[]> px; boost::weak_ptr<X> px2( px ); }
int main() { boost::shared_ptr<Y[]> px; boost::weak_ptr<X[]> px2( px ); }
void test() { { boost::interprocess::intrusive_ptr<X, VP> px; boost::interprocess::intrusive_ptr<X, VP> px2; px.swap(px2); BOOST_TEST(px.get() == 0); BOOST_TEST(px2.get() == 0); ::boost::adl_move_swap(px, px2); BOOST_TEST(px.get() == 0); BOOST_TEST(px2.get() == 0); } { boost::interprocess::offset_ptr<X> p = new X; boost::interprocess::intrusive_ptr<X, VP> px; boost::interprocess::intrusive_ptr<X, VP> px2(p); boost::interprocess::intrusive_ptr<X, VP> px3(px2); px.swap(px2); BOOST_TEST(px.get() == p); BOOST_TEST(px->use_count() == 2); BOOST_TEST(px2.get() == 0); BOOST_TEST(px3.get() == p); BOOST_TEST(px3->use_count() == 2); ::boost::adl_move_swap(px, px2); BOOST_TEST(px.get() == 0); BOOST_TEST(px2.get() == p); BOOST_TEST(px2->use_count() == 2); BOOST_TEST(px3.get() == p); BOOST_TEST(px3->use_count() == 2); } { boost::interprocess::offset_ptr<X> p1 = new X; boost::interprocess::offset_ptr<X> p2 = new X; boost::interprocess::intrusive_ptr<X, VP> px(p1); boost::interprocess::intrusive_ptr<X, VP> px2(p2); boost::interprocess::intrusive_ptr<X, VP> px3(px2); px.swap(px2); BOOST_TEST(px.get() == p2); BOOST_TEST(px->use_count() == 2); BOOST_TEST(px2.get() == p1); BOOST_TEST(px2->use_count() == 1); BOOST_TEST(px3.get() == p2); BOOST_TEST(px3->use_count() == 2); ::boost::adl_move_swap(px, px2); BOOST_TEST(px.get() == p1); BOOST_TEST(px->use_count() == 1); BOOST_TEST(px2.get() == p2); BOOST_TEST(px2->use_count() == 2); BOOST_TEST(px3.get() == p2); BOOST_TEST(px3->use_count() == 2); } }
int main() { boost::shared_ptr<X> px( new X ); { boost::shared_ptr<X> p2 = boost::atomic_load( &px ); BOOST_TEST_SP_EQ( p2, px ); boost::shared_ptr<X> px2( new X ); boost::atomic_store( &px, px2 ); BOOST_TEST_SP_EQ( px, px2 ); p2 = boost::atomic_load( &px ); BOOST_TEST_SP_EQ( p2, px ); BOOST_TEST_SP_EQ( p2, px2 ); boost::shared_ptr<X> px3( new X ); boost::shared_ptr<X> p3 = boost::atomic_exchange( &px, px3 ); BOOST_TEST_SP_EQ( p3, px2 ); BOOST_TEST_SP_EQ( px, px3 ); boost::shared_ptr<X> px4( new X ); boost::shared_ptr<X> cmp; bool r = boost::atomic_compare_exchange( &px, &cmp, px4 ); BOOST_TEST( !r ); BOOST_TEST_SP_EQ( px, px3 ); BOOST_TEST_SP_EQ( cmp, px3 ); r = boost::atomic_compare_exchange( &px, &cmp, px4 ); BOOST_TEST( r ); BOOST_TEST_SP_EQ( px, px4 ); } // px.reset(); { boost::shared_ptr<X> p2 = boost::atomic_load_explicit( &px, boost::memory_order_acquire ); BOOST_TEST_SP_EQ( p2, px ); boost::shared_ptr<X> px2( new X ); boost::atomic_store_explicit( &px, px2, boost::memory_order_release ); BOOST_TEST_SP_EQ( px, px2 ); boost::shared_ptr<X> p3 = boost::atomic_exchange_explicit( &px, boost::shared_ptr<X>(), boost::memory_order_acq_rel ); BOOST_TEST_SP_EQ( p3, px2 ); BOOST_TEST_SP_EQ( px, p2 ); boost::shared_ptr<X> px4( new X ); boost::shared_ptr<X> cmp( px2 ); bool r = boost::atomic_compare_exchange_explicit( &px, &cmp, px4, boost::memory_order_acquire, boost::memory_order_relaxed ); BOOST_TEST( !r ); BOOST_TEST_SP_EQ( px, p2 ); BOOST_TEST_SP_EQ( cmp, p2 ); r = boost::atomic_compare_exchange_explicit( &px, &cmp, px4, boost::memory_order_release, boost::memory_order_acquire ); BOOST_TEST( r ); BOOST_TEST_SP_EQ( px, px4 ); } return boost::report_errors(); }