std::mutex与pthread mutex区别

Linux下 pthread mutex

* PTHREAD_MUTEX_TIMED_NP,这是缺省值,也就是普通锁。当一个线程加锁以后,其余请求锁的线程将形成一个等待队列,并在解锁后按优先级获得锁。这种锁策略保证了资源分配的公平性。
* PTHREAD_MUTEX_RECURSIVE_NP,嵌套锁,允许同一个线程对同一个锁成功获得多次,并通过多次unlock解锁。如果是不同线程请求,则在加锁线程解锁时重新竞争。
* PTHREAD_MUTEX_ERRORCHECK_NP,检错锁,如果同一个线程请求同一个锁,则返回EDEADLK,否则与PTHREAD_MUTEX_TIMED_NP类型动作相同。这样就保证当不允许多次加锁时不会出现最简单情况下的死锁。
* PTHREAD_MUTEX_ADAPTIVE_NP,适应锁,动作最简单的锁类型,仅等待解锁后重新竞争。

std::mutex 只有是一种嵌套锁

线程A lock,只能由线程A unlock

http://www.cplusplus.com/reference/mutex/mutex/unlock/


并发控制

http://www.cnblogs.com/haippy/p/3284540.html


参考百度百科互斥锁

http://baike.baidu.com/link?url=gshO_9YUHZY1d03uH-yoV8IaGWzEt_8oXtTNzpjcVHGP5hOAE5ZEWaFyN711zQ0KI9SF6HBvPtllAf21Cmkdg2prj2QqvEaPRAUPDW3Tce3

posted @ 2017-02-22 16:47  jiu~  阅读(3214)  评论(0编辑  收藏  举报