アルゴリズムの決定が共有の深さに基づいている場合がありますstd::recursive_mutex
。
#include <iostream>
#include <mutex>
#include <thread>
int g_i = 0;
std::recursive_mutex g_i_mutex;
void bar() {
std::lock_guard<std::recursive_mutex> lock(g_i_mutex);
switch (get_counter(g_i_mutex)) { // some way to find the number of owners
case 1: std::cout << "depth 1\n"; break;
case 2: std::cout << "depth 2\n"; break;
default:;
}
}
void foo() {
std::lock_guard<std::recursive_mutex> lock(g_i_mutex);
std::cout << "hello\n";
bar();
}
int main() {
foo(); //print hello then depth 2
bar(); //print depth 1
}
再帰的ミューテックスが何らかの使用カウントを保持し、ロック/ロック解除の呼び出しごとに増減することを読んだことがありますが、その情報にアクセスする方法はありますか?