std::unique_lock<Mutex>:lock
Von cppreference.com
< cpp | thread | unique lock
| void lock(); |
(seit C++11) | |
Sperrt (d.h. übernimmt den Besitz) den zugeordneten Mutex. Ruft effektiv mutex()->lock() auf.
Inhalt |
[bearbeiten] Parameter
(keine)
[bearbeiten] Rückgabewert
(keine)
[bearbeiten] Ausnahmen
- Alle Ausnahmen, die von mutex()->lock() ausgelöst werden.
- Wenn kein zugeordneter Mutex vorhanden ist, std::system_error mit einem Fehlercode von std::errc::operation_not_permitted.
- Wenn der Mutex bereits von diesem
unique_lockgesperrt ist (mit anderen Worten, owns_lock() ist true), wird eine std::system_error mit dem Fehlercode std::errc::resource_deadlock_would_occur ausgelöst.
[bearbeiten] Beispiel
Das folgende Beispiel verwendet lock, um einen Mutex neu zu sperren, der zuvor entsperrt wurde.
Führen Sie diesen Code aus
#include <chrono> #include <iostream> #include <mutex> #include <thread> #include <vector> int main() { int counter = 0; std::mutex counter_mutex; std::vector<std::thread> threads; auto worker_task = [&](int id) { std::unique_lock<std::mutex> lock(counter_mutex); ++counter; std::cout << id << ", initial counter: " << counter << '\n'; lock.unlock(); // don't hold the lock while we simulate an expensive operation std::this_thread::sleep_for(std::chrono::seconds(1)); lock.lock(); ++counter; std::cout << id << ", final counter: " << counter << '\n'; }; for (int i = 0; i < 10; ++i) threads.emplace_back(worker_task, i); for (auto& thread : threads) thread.join(); }
Mögliche Ausgabe
0, initial counter: 1 1, initial counter: 2 2, initial counter: 3 3, initial counter: 4 4, initial counter: 5 5, initial counter: 6 6, initial counter: 7 7, initial counter: 8 8, initial counter: 9 9, initial counter: 10 6, final counter: 11 3, final counter: 12 4, final counter: 13 2, final counter: 14 5, final counter: 15 0, final counter: 16 1, final counter: 17 7, final counter: 18 9, final counter: 19 8, final counter: 20
[bearbeiten] Siehe auch
| versucht, den zugehörigen Mutex ohne Blockieren zu sperren (d.h. den Besitz zu übernehmen) (public member function) | |
| entsperrt den zugehörigen Mutex (d.h. gibt den Besitz frei) (public member function) |