Namensräume
Varianten

std::mutex

Aus cppreference.com
< cpp‎ | thread
 
 
Thema Support-Bibliothek
Threads
Original:
Threads
The text has been machine-translated via Google Translate.
You can help to correct and verify the translation. Click here for instructions.
thread(C++11)
this_thread Namespace
Original:
this_thread namespace
The text has been machine-translated via Google Translate.
You can help to correct and verify the translation. Click here for instructions.
get_id(C++11)
yield(C++11)
sleep_for(C++11)
sleep_until(C++11)
Gegenseitigen Ausschluss
Original:
Mutual exclusion
The text has been machine-translated via Google Translate.
You can help to correct and verify the translation. Click here for instructions.
mutex(C++11)
timed_mutex(C++11)
Generische Sperrverwaltung
Original:
Generic lock management
The text has been machine-translated via Google Translate.
You can help to correct and verify the translation. Click here for instructions.
lock(C++11)
try_lock(C++11)
defer_lock
try_to_lock
adopt_lock
(C++11)
(C++11)
(C++11)
Zustand Variablen
Original:
Condition variables
The text has been machine-translated via Google Translate.
You can help to correct and verify the translation. Click here for instructions.
condition_variable(C++11)
condition_variable_any(C++11)
notify_all_at_thread_exit(C++11)
cv_status(C++11)
Futures
Original:
Futures
The text has been machine-translated via Google Translate.
You can help to correct and verify the translation. Click here for instructions.
promise(C++11)
future(C++11)
shared_future(C++11)
packaged_task(C++11)
async(C++11)
 
std::mutex
Member-Funktionen
Original:
Member functions
The text has been machine-translated via Google Translate.
You can help to correct and verify the translation. Click here for instructions.
mutex::mutex
Sperren
Original:
Locking
The text has been machine-translated via Google Translate.
You can help to correct and verify the translation. Click here for instructions.
mutex::lock
mutex::try_lock
mutex::unlock
Ureinwohner Griff
Original:
Native handle
The text has been machine-translated via Google Translate.
You can help to correct and verify the translation. Click here for instructions.
mutex::native_handle
 
definiert in Header <mutex>
class mutex;
(seit C++11)

Die mutex Klasse ist eine Synchronisierungsgrundeinheit, die verwendet werden kann, um gemeinsame Daten vor gleichzeitigen Zugriffen aus mehreren Threads zu schützen.

mutex bietet exklusive, nicht-rekursive Eigentumssemantik:

  • Ein aufrufender Thread besitzt einen mutex von dem Zeitpunkt an, wo er entweder erfolgreich lock oder try_lock aufgerufen hat, bis er unlock aufruft.
  • Wenn ein Thread einen mutex besitzt, werden alle anderen Threads blockiert (bei Aufrufen von lock) oder erhalten einen false Rückgabewert (bei try_lock), wenn sie versuchen den Besitz des mutex anzufordern.
  • Ein aufrufender Thread darf nicht bereits im Besitz des mutex sein, wenn er lock oder try_lock aufruft.

Das Verhalten eines Programms ist undefiniert, wenn ein mutex zerstört wird, während er noch im Besitz eines Threads ist. Die mutex Klasse ist nicht kopierbar .

Inhaltsverzeichnis

[Bearbeiten]Mitglied Typen

Mitglied Typ Definition
native_handle_type Implementierungs definiert

[Bearbeiten]Member-Funktionen

konstruiert den Mutex
(öffentliche Elementfunktion)[edit]
Sperren
sperrt den Mutex, blockiert wenn der Mutex nicht verfügbar ist
(öffentliche Elementfunktion)[edit]
versucht den Mutex zu sperren und kehrt zurück, wenn der Mutex nicht verfügbar ist
(öffentliche Elementfunktion)[edit]
entsperrt den Mutex
(öffentliche Elementfunktion)[edit]
Natives Handle
gibt das zugrunde liegende implementierungsabhängige Thread-Handle zurück
(öffentliche Elementfunktion)[edit]

[Bearbeiten]Beispiel

Dieses Beispiel zeigt, wie ein mutex verwendet werden kann, um eine std::map zu schützen, die zwischen zwei Threads geteilt wird.

#include <iostream>#include <chrono>#include <thread>#include <mutex>#include <map>#include <string>   std::map<std::string, std::string> g_pages; std::mutex g_pages_mutex;   void save_page(conststd::string&url){// simulate a long page fetchstd::this_thread::sleep_for(std::chrono::seconds(2));std::string result ="fake content";   g_pages_mutex.lock(); g_pages[url]= result; g_pages_mutex.unlock();}   int main(){std::thread t1(save_page, "http://foo");std::thread t2(save_page, "http://bar"); t1.join(); t2.join();   g_pages_mutex.lock();for(constauto&pair : g_pages){std::cout<< pair.first<<" => "<< pair.second<<'\n';} g_pages_mutex.unlock();}

Output:

http://bar => fake content http://foo => fake content
close