名前空間
変種
操作

std::timed_mutex::lock

From cppreference.com
 
 
並行性サポートライブラリ
スレッド
(C++11)
(C++20)
this_thread 名前空間
(C++11)
(C++11)
(C++11)
協調的なキャンセル
排他制御
(C++11)
汎用ロック管理
(C++11)
(C++11)
(C++11)
(C++11)
(C++11)
条件変数
(C++11)
セマフォ
ラッチとバリア
(C++20)
(C++20)
future
(C++11)
(C++11)
(C++11)
(C++11)
安全なメモリ解放 (Safe Reclamation)
(C++26)
ハザードポインタ
アトミック型
(C++11)
(C++20)
アトミック型の初期化
(C++11)(C++20で非推奨)
(C++11)(C++20で非推奨)
メモリオーダー
(C++11)(C++26で非推奨)
アトミック操作のためのフリー関数
アトミックフラグのためのフリー関数
 
 
void lock();
(C++11以降)

ミューテックスをロックします。別のスレッドが既にミューテックスをロックしている場合、lock の呼び出しはロックが取得されるまで実行をブロックします。

既にmutexを所有しているスレッドによってlockが呼び出された場合、動作は未定義です。例えば、プログラムはデッドロックする可能性があります。無効な使用を検出できる実装は、デッドロックの代わりに、エラー条件resource_deadlock_would_occurを持つstd::system_errorをスローすることが推奨されます。

同じmutexに対する以前のunlock()操作は、この操作と同期します(std::memory_orderで定義されているように)。

目次

[編集] Parameters

(なし)

[編集] Return value

(なし)

[編集] Exceptions

エラーが発生した場合、および lock がその仕様を満たすのを妨げる基盤となるオペレーティングシステムからのエラーを含め、std::system_error をスローします。例外がスローされた場合、ミューテックスはロックされません。

[編集] Notes

lock() は通常直接呼び出されません。排他的ロックを管理するには、std::unique_lockstd::scoped_lock、および std::lock_guard が使用されます。


[編集] Example

この例では、共有データを保護するために lockunlock がどのように使用できるかを示しています。

#include <chrono>
#include <iostream>
#include <mutex>
#include <thread>
 
int g_num = 0; // protected by g_num_mutex
std::mutex g_num_mutex;
 
void slow_increment(int id) 
{
    for (int i = 0; i < 3; ++i)
    {
        g_num_mutex.lock(); 
        ++g_num;
        // note, that the mutex also syncronizes the output
        std::cout << "id: " << id << ", g_num: " << g_num << '\n';
        g_num_mutex.unlock();
 
        std::this_thread::sleep_for(std::chrono::milliseconds(234));
    }
}
 
int main()
{
    std::thread t1{slow_increment, 0};
    std::thread t2{slow_increment, 1};
    t1.join();
    t2.join();
}

実行結果の例

id: 0, g_num: 1
id: 1, g_num: 2
id: 1, g_num: 3
id: 0, g_num: 4
id: 0, g_num: 5
id: 1, g_num: 6

[編集] See also

ミューテックスをロックしようとします。ミューテックスが利用できない場合は戻ります
(public メンバ関数) [編集]
ミューテックスをロックしようとします。ミューテックスが
指定されたタイムアウト期間利用できなかった場合は戻ります
(public メンバ関数) [編集]
ミューテックスをロックしようとします。ミューテックスが
指定された時刻まで利用できなかった場合は戻ります
(public メンバ関数) [編集]
ミューテックスをアンロックします
(public メンバ関数) [編集]
C documentation for mtx_lock
English 日本語 中文(简体) 中文(繁體)