Standard library header <hazard_pointer> (C++26)
From cppreference.net
C++
Standard library headers
Cet en-tête fait partie de la bibliothèque de support des threads .
Classes |
||
|
(C++26)
|
permet à un objet d'être protégé par pointeur de risque
(modèle de classe) |
|
|
(C++26)
|
pointeur à un seul écrivain et plusieurs lecteurs qui ne peut être détenu que par un seul thread à un moment donné
(classe) |
|
Fonctions |
||
|
(C++26)
|
construit un pointeur de risque
(fonction) |
|
|
(C++26)
|
spécialise l'algorithme
std::swap
(modèle de fonction) |
|
Synopsis
namespace std { // hazard_pointer_obj_base template<class T, class D = default_delete<T>> class hazard_pointer_obj_base; // hazard_pointer class hazard_pointer; // make_hazard_pointer hazard_pointer make_hazard_pointer(); void swap(hazard_pointer&, hazard_pointer&) noexcept; }
Modèle de classe std::hazard_pointer_obj_base
namespace std { template<class T, class D = default_delete<T>> class hazard_pointer_obj_base { public: void retire(D d = D()) noexcept; protected: hazard_pointer_obj_base() = default; hazard_pointer_obj_base(const hazard_pointer_obj_base&) = default; hazard_pointer_obj_base(hazard_pointer_obj_base&&) = default; hazard_pointer_obj_base& operator=(const hazard_pointer_obj_base&) = default; hazard_pointer_obj_base& operator=(hazard_pointer_obj_base&&) = default; ~hazard_pointer_obj_base() = default; private: D deleter; // exposition uniquement }; }
Classe std::hazard_pointer
namespace std { class hazard_pointer { public: hazard_pointer() noexcept; hazard_pointer(hazard_pointer&&) noexcept; hazard_pointer& operator=(hazard_pointer&&) noexcept; ~hazard_pointer(); bool empty() const noexcept; template<class T> T* protect(const atomic<T*>& src) noexcept; template<class T> bool try_protect(T*& ptr, const atomic<T*>& src) noexcept; template<class T> void reset_protection(const T* ptr) noexcept; void reset_protection(nullptr_t = nullptr) noexcept; void swap(hazard_pointer&) noexcept; }; }