嗯,我是一个线程,我看不到其他线程,我眼里只有能访问的区域。咦,哪个区域怎么不给我访问,怎么上锁了,我想自己上锁的。我等待把,我等了1000ms还是没等待成功,我该走还是改怎么办呢?他这个锁是超时的,我自己写了一部分代码,检测他是否超时,不然我一直等下去多甜狗。
timed_mutex tmux; //超时锁
if (!tmux.try_lock_for(chrono::milliseconds(1000ms)))
{
//尝试锁住(尝试获取资源,等1000ms
//等了1000ms之后发现,还是没能lock这个临界区,也就是无法获取资源,这个线程就开始抱怨了
cout<<i<<"[time_out]"<<endl;
continue;
}
//成功获取资源
cout<<i<<"[in]"<<endl;
//完成共享区任务后,解锁
tmux.unlock();
this_thread::sleep_for(1ms)
};
整体代码:
/*
笔记:n个线程竞争一个资源,使用临界区上锁方式规定只允许每次一个线程访问该临界区获取资源。临界区需要做得比较小,否则导致资源浪费
久久不得响应
*/
#include <thread>
#include <iostream>
#include <mutex>
using namespace std;
timed_mutex tmux; //超时锁
static mutex mux;
void test_main(int i) {
while (1) {
if (!tmux.try_lock_for(chrono::milliseconds(1000ms)))
{
//尝试锁住(尝试获取资源,等1000ms
//等了1000ms之后发现,还是没能lock这个临界区,也就是无法获取资源,这个线程就开始抱怨了
cout<<i<<"[time_out]"<<endl;
continue;
}
//成功获取资源
cout<<i<<"[in]"<<endl;
//完成共享区任务后,解锁
tmux.unlock();
this_thread::sleep_for(1ms);
}
}
int main() {
for (int i = 0; i < 3; i++)
{//并发8个线程
std::thread tid(test_main,i+1);
tid.detach();
}
getchar();
return 0;
}