std::shared_lock<Mutex>:: lock
From cppreference.net
<
cpp
|
thread
|
shared lock
C++
Concurrency support library
|
|
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
std::shared_lock
| Member functions | ||||
| Shared locking | ||||
|
shared_lock::lock
|
||||
| Modifiers | ||||
| Observers | ||||
| Non-member functions | ||||
|
void
lock
(
)
;
|
(depuis C++14) | |
Verrouille le mutex associé en mode partagé. Appelle effectivement mutex ( ) - > lock_shared ( ) .
Table des matières |
Paramètres
(aucun)
Valeur de retour
(aucun)
Exceptions
- Toute exception levée par mutex ( ) - > lock_shared ( ) .
- S'il n'y a pas de mutex associé, std::system_error avec un code d'erreur de std::errc::operation_not_permitted .
-
Si le mutex associé est déjà verrouillé par ce
shared_lock(c'est-à-dire que owns_lock renvoie true ), std::system_error avec un code d'erreur de std::errc::resource_deadlock_would_occur .
Exemple
|
Cette section est incomplète
Raison : montrer une utilisation significative de shared_lock::lock |
Exécuter ce code
#include <iostream> #include <mutex> #include <shared_mutex> #include <string> #include <thread> std::string file = "Original content."; // Simule un fichier std::mutex output_mutex; // mutex qui protège les opérations de sortie. std::shared_mutex file_mutex; // mutex lecteur/rédacteur void read_content(int id) { std::string content; { std::shared_lock lock(file_mutex, std::defer_lock); // Ne pas le verrouiller d'abord. lock.lock(); // Verrouiller ici. content = file; } std::lock_guard lock(output_mutex); std::cout << "Contents read by reader #" << id << ": " << content << '\n'; } void write_content() { { std::lock_guard file_lock(file_mutex); file = "New content"; } std::lock_guard output_lock(output_mutex); std::cout << "New content saved.\n"; } int main() { std::cout << "Two readers reading from file.\n" << "A writer competes with them.\n"; std::thread reader1{read_content, 1}; std::thread reader2{read_content, 2}; std::thread writer{write_content}; reader1.join(); reader2.join(); writer.join(); std::cout << "The first few operations to file are done.\n"; reader1 = std::thread{read_content, 3}; reader1.join(); }
Sortie possible :
Two readers reading from file. A writer competes with them. Contents read by reader #1: Original content. Contents read by reader #2: Original content. New content saved. The first few operations to file are done. Contents read by reader #3: New content
Voir aussi
|
tente de verrouiller le mutex associé
(fonction membre publique) |
|
|
déverrouille le mutex associé
(fonction membre publique) |