Namespaces
Variants

std::unique_lock<Mutex>:: lock

From cppreference.net
Concurrency support library
Threads
(C++11)
(C++20)
this_thread namespace
(C++11)
(C++11)
Cooperative cancellation
Mutual exclusion
Generic lock management
Condition variables
(C++11)
Semaphores
Latches and Barriers
(C++20)
(C++20)
Futures
(C++11)
(C++11)
(C++11)
Safe reclamation
Hazard pointers
Atomic types
(C++11)
(C++20)
Initialization of atomic types
(C++11) (deprecated in C++20)
(C++11) (deprecated in C++20)
Memory ordering
(C++11) (deprecated in C++26)
Free functions for atomic operations
Free functions for atomic flags
void lock ( ) ;
(seit C++11)

Sperrt (d.h. übernimmt den Besitz des) zugehörigen Mutex. Effektiv wird mutex ( ) - > lock ( ) aufgerufen.

Inhaltsverzeichnis

Parameter

(keine)

Rückgabewert

(keine)

Ausnahmen

  • Alle Ausnahmen, die von mutex ( ) - > lock ( ) geworfen werden.

Beispiel

Das folgende Beispiel verwendet lock , um ein Mutex erneut zu erwerben, das zuvor freigegeben wurde.

#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

Siehe auch

versucht, den zugehörigen Mutex ohne Blockierung zu sperren (d.h. übernimmt den Besitz)
(öffentliche Elementfunktion)
entsperrt (d.h. gibt den Besitz des) zugehörigen Mutex frei
(öffentliche Elementfunktion)