C++11中提供了多线程的机制,从而不可避免的提供了一些锁用于控制对共享数据的访问。
1:std::Mutex
最基本的互斥量,线程在使用时,需要先调用lock或try_lock函数获取锁,然后对共享数据进行操作,操作完成后调用unlock解锁,该互斥量不支持在同一个线程中多次调用lock。
2:std::recursive_mutex
支持递归的互斥量,使用方法与mutex类似,但支持同一个线程进行多次加锁,当然解锁的时候需要进行多次解锁。
3:std::shared_mutex
一个读写锁,支持多个线程获取读锁,从而允许多个线程同时读取共享数据。该锁提供了lock和lock_shared方法,如果某一个线程通过lock获取了写锁,则其他线程无法获取锁,如果有线程通过lock_shared获取了读锁,其他线程也可以通过lock_shared获取读锁。