Archivo de encabezado de la biblioteca estándar <hazard_pointer> (C++26)
De cppreference.com
Este archivo de encabezado es parte de la biblioteca de apoyo de hilos/subprocesos.
Clases | |
(C++26) |
Permite que un objeto sea protegible contra riesgos. (plantilla de clase) |
(C++26) |
Puntero multilector de un solo escritor que puede ser propiedad de, como máximo, un hilo en cualquier momento. (clase) |
Funciones | |
(C++26) |
Construye un puntero de riesgo. (función) |
| Especializa el algoritmo std::swap. (plantilla de función) | |
Sinopsis
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;
}
Plantilla de clase 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; // solo para exposición
};
}
Clase 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;
};
}