liuxiaolong
2021-07-20 58d904a328c0d849769b483e901a0be9426b8209
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
#ifndef BOOST_SMART_PTR_DETAIL_ATOMIC_COUNT_WIN32_HPP_INCLUDED
#define BOOST_SMART_PTR_DETAIL_ATOMIC_COUNT_WIN32_HPP_INCLUDED
 
// MS compatible compilers support #pragma once
 
#if defined(_MSC_VER) && (_MSC_VER >= 1020)
# pragma once
#endif
 
//
//  boost/detail/atomic_count_win32.hpp
//
//  Copyright (c) 2001-2005 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)
//
 
#include <boost/smart_ptr/detail/sp_interlocked.hpp>
 
#if defined(BOOST_SP_REPORT_IMPLEMENTATION)
 
#include <boost/config/pragma_message.hpp>
BOOST_PRAGMA_MESSAGE("Using Win32 atomic_count")
 
#endif
 
namespace boost
{
 
namespace detail
{
 
class atomic_count
{
public:
 
    explicit atomic_count( long v ): value_( v )
    {
    }
 
    long operator++()
    {
        return BOOST_SP_INTERLOCKED_INCREMENT( &value_ );
    }
 
    long operator--()
    {
        return BOOST_SP_INTERLOCKED_DECREMENT( &value_ );
    }
 
    operator long() const
    {
        return static_cast<long const volatile &>( value_ );
    }
 
private:
 
    atomic_count( atomic_count const & );
    atomic_count & operator=( atomic_count const & );
 
    long value_;
};
 
} // namespace detail
 
} // namespace boost
 
#endif // #ifndef BOOST_SMART_PTR_DETAIL_ATOMIC_COUNT_WIN32_HPP_INCLUDED