std::atomic_...<std::shared_ptr>
template< class T >
bool atomic_is_lock_free( const std::shared_ptr<T>* p ); |
(1) | (since C++11) |
template< class T >
std::shared_ptr<T> atomic_load( const std::shared_ptr<T>* p ); |
(2) | (since C++11) |
template< class T >
std::shared_ptr<T> atomic_load_explicit( const std::shared_ptr<T>* p, |
(3) | (since C++11) |
template< class T >
void atomic_store( std::shared_ptr<T>* p, |
(4) | (since C++11) |
template< class T >
void atomic_store_explicit( std::shared_ptr<T>* p, |
(5) | (since C++11) |
template< class T >
std::shared_ptr<T> atomic_exchange( std::shared_ptr<T>* p, |
(6) | (since C++11) |
template<class T>
std::shared_ptr<T> atomic_exchange_explicit( std::shared_ptr<T>* p, |
(7) | (since C++11) |
template< class T >
bool atomic_compare_exchange_weak( std::shared_ptr<T>* p, |
(8) | (since C++11) |
template<class T>
bool atomic_compare_exchange_strong( std::shared_ptr<T>* p, |
(9) | (since C++11) |
template< class T >
bool atomic_compare_exchange_strong_explicit( std::shared_ptr<T>* p, |
(10) | (since C++11) |
template< class T >
bool atomic_compare_exchange_weak_explicit( std::shared_ptr<T>* p, |
(11) | (since C++11) |
If multiple threads of execution access the same std::shared_ptr object without synchronization and any of those accesses uses a non-const member function of shared_ptr then a data race will occur unless all such access is performed through these functions, which are overloads of the corresponding atomic access functions (std::atomic_load, std::atomic_store, etc.)
Note that the control block of a shared_ptr is thread-safe: different std::shared_ptr objects can be accessed using mutable operations, such as operator= or reset, simultaneously by multiple threads, even when these instances are copies, and share the same control block internally.
p
is lock-free.p
. As with the non-specialized std::atomic_load_explicit, mo
cannot be std::memory_order_release or std::memory_order_acq_rel
r
in the shared pointer pointed-to by p
atomically, effectively executing p->swap(r). As with the non-specialized std::atomic_store_explicit, mo
cannot be std::memory_order_acquire or std::memory_order_acq_rel.r
in the shared pointer pointed to by p
and returns the value formerly pointed-to by p
, atomically. Effectively executes p->swap(r) and returns a copy of r
after the swap.p
and expected
. If they are equivalent (share ownership of the same pointer and refer to the same pointer), assigns desired
into *p
using the memory ordering constraints specified by success
and returns true. If they are not equivalent, assigns *p
into *expected
using the memory ordering constraints specified by failure
and returns false.All these functions invoke undefined behavior if p
is a null pointer.
Contents |
[edit] Parameters
p, expected | - | a pointer to a std::shared_ptr |
r, desired | - | a std::shared_ptr |
mo, success, failure | - | memory ordering selectors of type std::memory_order |
[edit] Exceptions
These functions do not throw exceptions.
[edit] Return value
[edit] Notes
The Concurrency TS offers atomic smart pointer classes atomic_shared_ptr
and atomic_weak_ptr
as a replacement for the use of these functions.
[edit] Example
This section is incomplete Reason: no example |
[edit] See also
(C++11)
|
checks if the atomic type's operations are lock-free (function template) |
(C++11)(C++11)
|
atomically replaces the value of the atomic object with a non-atomic argument (function template) |
(C++11)(C++11)
|
atomically obtains the value stored in an atomic object (function template) |
(C++11)(C++11)
|
atomically replaces the value of the atomic object with non-atomic argument and returns the old value of the atomic (function template) |
atomically compares the value of the atomic object with non-atomic argument and performs atomic exchange if equal or atomic load if not (function template) |