std::atomic_...std::shared_ptr - cppreference.com (original) (raw)
| Defined in header | ||
|---|---|---|
| template< class T > bool atomic_is_lock_free( const std::shared_ptr<T>* p ); | (1) | (since C++11) (deprecated in C++20) (removed in C++26) |
| template< class T > std::shared_ptr<T> atomic_load( const std::shared_ptr<T>* p ); | (2) | (since C++11) (deprecated in C++20) (removed in C++26) |
| template< class T > std::shared_ptr<T> atomic_load_explicit ( const std::shared_ptr<T>* p, std::memory_order mo ); | (3) | (since C++11) (deprecated in C++20) (removed in C++26) |
| template< class T > void atomic_store( std::shared_ptr<T>* p, std::shared_ptr<T> r ); | (4) | (since C++11) (deprecated in C++20) (removed in C++26) |
| template< class T > void atomic_store_explicit ( std::shared_ptr<T>* p, std::shared_ptr<T> r, std::memory_order mo ); | (5) | (since C++11) (deprecated in C++20) (removed in C++26) |
| template< class T > std::shared_ptr<T> atomic_exchange ( std::shared_ptr<T>* p, std::shared_ptr<T> r ); | (6) | (since C++11) (deprecated in C++20) (removed in C++26) |
| template< class T > std::shared_ptr<T> atomic_exchange_explicit ( std::shared_ptr<T>* p, std::shared_ptr<T> r, std::memory_order mo ); | (7) | (since C++11) (deprecated in C++20) (removed in C++26) |
| template< class T > bool atomic_compare_exchange_weak ( std::shared_ptr<T>* p, std::shared_ptr<T>* expected, std::shared_ptr<T> desired ); | (8) | (since C++11) (deprecated in C++20) (removed in C++26) |
| template< class T > bool atomic_compare_exchange_strong ( std::shared_ptr<T>* p, std::shared_ptr<T>* expected, std::shared_ptr<T> desired ); | (9) | (since C++11) (deprecated in C++20) (removed in C++26) |
| template< class T > bool atomic_compare_exchange_strong_explicit ( std::shared_ptr<T>* p, std::shared_ptr<T>* expected, std::shared_ptr<T> desired, std::memory_order success, std::memory_order failure ); | (10) | (since C++11) (deprecated in C++20) (removed in C++26) |
| template< class T > bool atomic_compare_exchange_weak_explicit ( std::shared_ptr<T>* p, std::shared_ptr<T>* expected, std::shared_ptr<T> desired, std::memory_order success, std::memory_order failure ); | (11) | (since C++11) (deprecated in C++20) (removed in C++26) |
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.
Determines whether atomic access to the shared pointer pointed-to by p is lock-free.
Returns the shared pointer pointed-to by p.
Stores the shared pointer r in the shared pointer pointed-to by p atomically, as if by p->swap(r).
Stores the shared pointer r in the shared pointer pointed to by p and returns the value formerly pointed-to by p, atomically, as if by p->swap(r) and returns a copy of r after the swap.
Equivalent to
Equivalent to
10,11) Compares the shared pointers pointed-to by p and expected.
- If they are equivalent (store the same pointer value, and either share ownership of the same object or are both empty), 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.
atomic_compare_exchange_weak_explicit may fail spuriously.
If p is a null pointer, the behaviors of these functions are all undefined.
Contents
[edit] Parameters
[edit] Exceptions
These functions do not throw exceptions.
[edit] Return value
- true if atomic access is implemented using lock-free instructions.
2,3) A copy of the pointed-to shared pointer.
4,5) (none)
6,7) A copy of the formerly pointed-to shared pointer.
8-11) true if the shared pointers were equivalent and the exchange was performed, false otherwise.
[edit] Notes
These functions are typically implemented using mutexes, stored in a global hash table where the pointer value is used as the key.
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
[edit] Defect reports
The following behavior-changing defect reports were applied retroactively to previously published C++ standards.
| DR | Applied to | Behavior as published | Correct behavior |
|---|---|---|---|
| LWG 2172 | C++11 | expected could be a null pointer | the behavior is undefined in this case |
| LWG 2980 | C++11 | empty shared_ptrs were never equivalent | equivalent if they store the same pointer value |