读写锁
读写锁就是分了两种情况,一种是读时的锁,一种是写时的锁,它允许多个线程同时读共享变量,但是只允许一个线程写共享变量,当写共享变量的时候也会阻塞读的操作。这样在读的时候就不会互斥,提高读的效率。
读写锁用来读写缓存
步骤
1、加读锁,从缓存读取key对应的value;
2、若读取到,则返回,并释放读锁;若没读取到,则释放读锁,然后立刻加写锁,再判断此时value是否是空,若还是空则从DB中查询得到结果value,并写入到缓存中,释放写锁,加读锁。
用读写锁写一个缓存
可重入锁
可重入锁指的是在同一个线程内如果你的外层函数已经获得了锁,那么当你的内层函数尝试获取锁时也能获得锁,也就是通过一个线程再次进入同步代码块时可以获得自己已经获得的锁,而不可重入则反之。看下简单的示例
void doSth(){ //外层函数
mutex.lock();
do(); //内层函数
mutex.unlock();
}
void do(){
mutex.lock();
//do something
mutex.unlock();
}