<shared_mutex>
L'intestazione <shared_mutex>
fornisce primitive di sincronizzazione per la protezione dei dati condivisi a cui è possibile accedere da più thread. Oltre a fornire il controllo di accesso esclusivo, le classi mutex consentono anche la proprietà condivisa da più thread per l'accesso non esclusivo. I mutex condivisi consentono di controllare le risorse che possono essere lette da più thread, ma devono essere scritte esclusivamente da un unico thread, senza causare una race condition.
L'intestazione <shared_mutex>
definisce le classi shared_mutex
e shared_timed_mutex
, il modello shared_lock
di classe e la funzione swap
modello per il supporto mutex condiviso.
Classi | Descrizione |
---|---|
Classe shared_mutex | Tipo mutex condiviso che può essere bloccato in modo esclusivo da un solo agente o condiviso in modo non esclusivo da più agenti. |
Classe shared_timed_mutex | Tipo mutex condiviso programmato che può essere bloccato in modo esclusivo da un solo agente o condiviso in modo non esclusivo da più agenti. |
Classe shared_lock | Modello di classe che esegue il wrapping di un mutex condiviso per supportare le operazioni di blocco a tempo e la condivisione non esclusiva da parte di più agenti. |
Funzioni | Descrizione |
---|---|
swap | Scambia il contenuto degli oggetti mutex condivisi a cui fanno riferimento i parametri della funzione. |
Sintassi
namespace std {
class shared_mutex;
class shared_timed_mutex;
template <class Mutex>
class shared_lock;
template <class Mutex>
void swap(shared_lock<Mutex>& x, shared_lock<Mutex>& y) noexcept;
}
Osservazioni:
Un'istanza della classe shared_mutex
è un tipo mutex condiviso, ovvero un tipo che controlla la proprietà condivisa di un mutex all'interno di un ambito. Un tipo mutex condiviso soddisfa tutti i requisiti di un tipo mutex, nonché quelli dei membri, per supportare la proprietà condivisa non esclusiva.
Un tipo mutex condiviso supporta i metodi aggiuntivi lock_shared
, unlock_shared
e try_lock_shared
:
Il metodo
lock_shared
blocca il thread chiamante finché quest'ultimo non ottiene la proprietà condivisa del mutex.Il metodo
unlock_shared
rilascia la proprietà condivisa del mutex detenuta dal thread chiamante.Il metodo
try_lock_shared
tenta di ottenere la proprietà condivisa del mutex senza blocco. Il tipo restituito è convertibile inbool
etrue
se il metodo ottiene la proprietà, mentre altrimenti èfalse
.
La classe shared_timed_mutex
è un tipo mutex condiviso programmato, ovvero un tipo che soddisfa i requisiti sia di un tipo mutex condiviso che di un tipo mutex programmato.
Un tipo mutex condiviso programmato supporta i metodi aggiuntivi try_lock_shared_for
e try_lock_shared_until
:
Il metodo
try_lock_shared_for
tenta di ottenere la proprietà condivisa del mutex fino a quando non è trascorso il periodo di tempo specificato dal parametro. Se il periodo di tempo non è positivo, il metodo è equivalente atry_lock_shared
. Il metodo non restituisce valori entro il periodo di tempo specificato a meno che non ottenga la proprietà condivisa. Il valore restituito ètrue
se il metodo ottiene la proprietà; in caso contrario, èfalse
.Il metodo
try_lock_shared_until
tenta di ottenere la proprietà condivisa del mutex fino a quando non è trascorso il tempo assoluto specificato. Se il tempo assoluto specificato è già trascorso, il metodo è equivalente atry_lock_shared
. Il metodo non restituisce valori prima dell'ora specificata a meno che non ottenga la proprietà condivisa. Il valore restituito ètrue
se il metodo ottiene la proprietà; in caso contrario, èfalse
.
Il modello di classe estende il shared_lock
supporto per il blocco timed e il trasferimento della proprietà a un mutex condiviso. La proprietà del mutex può essere ottenuta al momento della costruzione o dopo di essa e può essere trasferita a un altro oggetto shared_lock
. Gli oggetti di tipo shared_lock
possono essere spostati ma non copiati.
Avviso
A partire da Visual Studio 2015, i tipi di sincronizzazione della libreria standard C++ sono basati su primitive di sincronizzazione di Windows e non usano più ConcRT (tranne quando la piattaforma di destinazione è Windows XP). I tipi definiti in <shared_mutex>
non devono essere usati con qualsiasi tipo o funzione ConcRT.
Classi
Classe shared_mutex
La classe shared_mutex
implementa un mutex non ricorsivo con semantica di proprietà condivisa.
class shared_mutex {
public:
shared_mutex();
~shared_mutex();
shared_mutex(const shared_mutex&) = delete;
shared_mutex& operator=(const shared_mutex&) = delete;
// Exclusive ownership
void lock();
// blocking
bool try_lock();
void unlock();
// Shared ownership
void lock_shared();
// blocking
bool try_lock_shared();
void unlock_shared();
// Getters
typedef void** native_handle_type; // implementation defined
native_handle_type native_handle();
};
Classe shared_timed_mutex
La classe shared_timed_mutex
implementa un mutex non ricorsivo con semantica di proprietà condivisa che soddisfa i requisiti di un tipo mutex programmato.
class shared_timed_mutex {
public:
shared_timed_mutex();
~shared_timed_mutex();
shared_timed_mutex(const shared_timed_mutex&) = delete;
shared_timed_mutex& operator=(const shared_timed_mutex&) = delete;
// Exclusive ownership
void lock();
// blocking
bool try_lock();
template <class Rep, class Period>
bool try_lock_for(const chrono::duration<Rep, Period>& rel_time);
template <class Clock, class Duration>
bool try_lock_until(const chrono::time_point<Clock, Duration>& abs_time);
void unlock();
// Shared ownership
void lock_shared();
// blocking
bool try_lock_shared();
template <class Rep, class Period>
bool try_lock_shared_for(const chrono::duration<Rep, Period>& rel_time);
template <class Clock, class Duration>
bool try_lock_shared_until(const chrono::time_point<Clock, Duration>& abs_time);
void unlock_shared();
};
Classe shared_lock
Il modello shared_lock
di classe controlla la proprietà condivisa di un oggetto mutex condiviso all'interno di un ambito. Il parametro di modello deve essere un tipo mutex condiviso.
class shared_lock {
public:
typedef Mutex mutex_type;
shared_lock() noexcept;
explicit shared_lock(mutex_type& m);
// blocking
shared_lock(mutex_type& m, defer_lock_t) noexcept;
shared_lock(mutex_type& m, try_to_lock_t);
shared_lock(mutex_type& m, adopt_lock_t);
template <class Clock, class Duration>
shared_lock(mutex_type& m,
const chrono::time_point<Clock, Duration>& abs_time);
template <class Rep, class Period>
shared_lock(mutex_type& m,
const chrono::duration<Rep, Period>& rel_time);
~shared_lock();
shared_lock(shared_lock const&) = delete;
shared_lock& operator=(shared_lock const&) = delete;
shared_lock(shared_lock&& u) noexcept;
shared_lock& operator=(shared_lock&& u) noexcept;
void lock();
// blocking
bool try_lock();
template <class Rep, class Period>
bool try_lock_for(const chrono::duration<Rep, Period>& rel_time);
template <class Clock, class Duration>
bool try_lock_until(const chrono::time_point<Clock, Duration>& abs_time);
void unlock();
// Setters
void swap(shared_lock& u) noexcept;
mutex_type* release() noexcept;
// Getters
bool owns_lock() const noexcept;
explicit operator bool () const noexcept;
mutex_type* mutex() const noexcept;
private:
mutex_type* pm; // exposition only
bool owns; // exposition only
};
Funzioni
scambio
Scambia gli oggetti shared_lock
.
template <class Mutex>
void swap(shared_lock<Mutex>& x, shared_lock<Mutex>& y) noexcept;
Scambia il contenuto di due oggetti shared_lock
. È effettivamente uguale a x.swap(y)
.
Requisiti
Intestazione:<shared_mutex>
Spazio dei nomi: std