什么是递归锁
递归锁是一种特殊的线程同步机制,它允许同一线程在持有锁的情况下多次获得同一把锁。
递归锁通常用于解决线程递归调用中需要多次获取同一把锁的情况,以及防止死锁。递归锁内部维护一个计数器,用于记录同一线程获得锁的次数。每次成功获得锁,计数器加一;每次释放锁,计数器减一。同一线程多次获得锁时,不会造成阻塞。在释放锁的过程中,线程需要相应次数地释放锁,只有当计数器降为零时,其他线程才有机会获得锁。
linux、windows中哪些锁是递归锁,哪些不是
在Linux中,pthread_mutex_t锁默认是非递归锁,但可以通过设置PTHREAD_MUTEX_RECURSIVE属性将其变为递归锁。Windows下的Mutex和Critical Section则是可递归的。
递归锁和非递归锁的主要区别在于同一个线程是否可以多次获取同一个锁而不产生死锁。递归锁允许同一个线程多次获取同一个锁,只有在多次解锁之后才能真正释放锁;而非递归锁则不允许同一个线程在加锁后再次获取该锁,否则可能产生死锁。在使用这两种锁时,需要根据具体场景和需求来选择,以避免出现死锁或其他同步问题。
标签:同一个,递归,哪些,windows,计数器,多次,死锁,线程,linux From: https://blog.csdn.net/slty_123/article/details/137118788