sp_atomic_mt_test.cpp

来自「Boost provides free peer-reviewed portab」· C++ 代码 · 共 192 行

CPP
192
字号
// Copyright (c) 2008 Peter Dimov//// Distributed under the Boost Software License, Version 1.0.// See accompanying file LICENSE_1_0.txt or copy at// http://www.boost.org/LICENSE_1_0.txt//#define USE_MUTEX//#define USE_RWLOCK#include <boost/config.hpp>#include <boost/shared_ptr.hpp>#include <boost/bind.hpp>#if defined( USE_RWLOCK )#include <boost/thread/shared_mutex.hpp>#include <boost/thread/locks.hpp>#endif#include <boost/detail/lightweight_mutex.hpp>#include <boost/detail/lightweight_test.hpp>#include <boost/detail/lightweight_thread.hpp>#include <cstdio>#include <ctime>//int const n = 1024 * 1024;struct X{    int v_; // version    unsigned a_;    unsigned b_;    X(): v_( 0 ), a_( 1 ), b_( 1 )    {    }    int get() const    {        return a_ * 7 + b_ * 11;    }    void set()    {        int tmp = get();        b_ = a_;        a_ = tmp;        ++v_;    }};static boost::shared_ptr<X> ps( new X );static boost::detail::lightweight_mutex lm;#if defined( USE_RWLOCK )static boost::shared_mutex rw;#endifstatic int tr = 0;void reader( int r ){    int k = 0;    unsigned s = 0;    for( int i = 0; i < n; ++k )    {#if defined( USE_MUTEX )        boost::detail::lightweight_mutex::scoped_lock lock( lm );        s += ps->get();        BOOST_TEST( ps->v_ >= i );        i = ps->v_;#elif defined( USE_RWLOCK )        boost::shared_lock<boost::shared_mutex> lock( rw );        s += ps->get();        BOOST_TEST( ps->v_ >= i );        i = ps->v_;#else        boost::shared_ptr<X> p2 = boost::atomic_load( &ps );        s += p2->get();        BOOST_TEST( p2->v_ >= i );        i = p2->v_;#endif    }    printf( "Reader %d: %9d iterations (%6.3fx), %u\n", r, k, (double)k / n, s );    boost::detail::lightweight_mutex::scoped_lock lock( lm );    tr += k;}void writer(){    for( int i = 0; i < n; ++i )    {#if defined( USE_MUTEX )        boost::detail::lightweight_mutex::scoped_lock lock( lm );        BOOST_TEST( ps->v_ == i );        ps->set();#elif defined( USE_RWLOCK )        boost::unique_lock<boost::shared_mutex> lock( rw );        BOOST_TEST( ps->v_ == i );        ps->set();#else        boost::shared_ptr<X> p2( new X( *ps ) );        BOOST_TEST( p2->v_ == i );        p2->set();        boost::atomic_store( &ps, p2 );#endif    }}#if defined( BOOST_HAS_PTHREADS )  char const * thmodel = "POSIX";#else  char const * thmodel = "Windows";#endifint const mr = 8; // reader threadsint const mw = 1; // writer thread#if defined( USE_MUTEX )  char const * prim = "mutex";#elif defined( USE_RWLOCK )  char const * prim = "rwlock";#else  char const * prim = "atomics";#endifint main(){    using namespace std; // printf, clock_t, clock    printf( "Using %s threads: %dR + %dW threads, %d iterations, %s\n\n", thmodel, mr, mw, n, prim );    clock_t t = clock();    pthread_t a[ mr+mw ];    for( int i = 0; i < mr; ++i )    {        boost::detail::lw_thread_create( a[ i ], boost::bind( reader, i ) );    }    for( int i = mr; i < mr+mw; ++i )    {        boost::detail::lw_thread_create( a[ i ], writer );    }    for( int j = 0; j < mr+mw; ++j )    {        pthread_join( a[ j ], 0 );    }    t = clock() - t;    double ts = static_cast<double>( t ) / CLOCKS_PER_SEC;    printf( "%.3f seconds, %.3f reads per microsecond.\n", ts, tr / ts / 1e+6 );    return boost::report_errors();}

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?