并发,std::mutex

梦想游戏人
目录:
现代C++

互斥锁

任意时刻只有一个线程能访问互斥资源,一个程序中可以拥有多把锁,但是每一把锁 只有一个线程有访问权限,锁可以看做是一个多线程访问的资源

.


std::mutex _mutex;//全局锁

 int x = 0;//资源

void func_1()
{
	for (int i = 0; i < 500000; i++)
	{
	//lock 只能调用一次,如果多次可用recursive_mutex
		_mutex.lock();//访问公共资源时,互斥,获取访问权,如果失败则阻塞直到获得访问权
		//try_lock 获取失败则返回false 并不阻塞
		x+=1;
		_mutex.unlock();//释放资源
        //lock_guard 类 和 unique_lock 类可自动管理mutex的lock和unlock ,//相当于指针的 智能指针管理new delete一样属于RAII

	}
}

int main(int argc, char *argv[])
{

	auto t = std::thread(func_1);

	t.detach();

	auto t1 = std::thread(func_1);

	t1.detach();

	Sleep(1000);

	cout << x << endl;
	cout << "main thread" << endl;
	  


	system("pause");
	return 0;
}


递归锁 std::recursive_mutex: 同一个线程如果获取了锁,再次加锁 那么永远将会死锁

时间锁  允许在一定时间内等待,可以避免死锁

	std::thread t([&]
	{
		//while (true)
		{
			Sleep(100);
			cout << mm.try_lock_for(std::chrono::seconds(1)) << endl;// 最多柱塞等待一秒,
			cout << __FUNCTION__ << endl;
			mm.unlock();
		}

	});
	t.detach();

	mm.lock();
	cout << __FUNCTION__ << endl;
	Sleep(500);
	mm.unlock();

MSDN参考,https://msdn.microsoft.com/en-us/library/hh921467(v=vs.120).aspx

Scroll Up