名稱空間
變體
操作

std::unique_lock<Mutex>::lock

來自 cppreference.com
< cpp‎ | thread‎ | unique lock
 
 
併發支援庫
執行緒
(C++20)
this_thread 名稱空間
(C++11)
(C++11)
(C++11)
協同取消
互斥
通用鎖管理
條件變數
(C++11)
訊號量
門閂和屏障
(C++20)
(C++20)
期值
安全回收
(C++26)
危險指標
原子型別
(C++20)
原子型別的初始化
(C++11)(C++20 中已棄用)
(C++11)(C++20 中已棄用)
記憶體排序
(C++11)(C++26 中已棄用)
原子操作的自由函式
原子標誌的自由函式
 
 
void lock();
(C++11 起)

鎖定(即,獲取關聯互斥體的所有權)。實質上呼叫 mutex()->lock()

目錄

[編輯] 引數

(無)

[編輯] 返回值

(無)

[編輯] 異常

  • 任何由 mutex()->lock() 丟擲的異常。

[編輯] 示例

以下示例使用 lock 重新獲取已解鎖的互斥體。

#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();
}

可能的輸出

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

[編輯] 參閱

嘗試鎖定(即獲取)關聯的互斥量而不阻塞
(public member function) [編輯]
解鎖(即釋放)關聯的互斥量
(public member function) [編輯]