读写锁
读写锁主要是和数据库的几种隔离方式向对应
Serializable | 只要有事务对某个表进行操作,其他事务只能等待,采取锁表的方式 |
Repeatable read | 采用读写锁,只要有事务在读,就不允许其他事务进行写操作(对应读优先) |
Read commit | 采用读写锁,只要有事务在写,就不允许其他事物进行读操作(对应写优先) |
Read uncommitte | 非安全型 |
读优先读写锁:
读者优先:只要有读者要读,写者就不能写,如果前面的读者还没走就来了新的读者,那么新的读者又会读,所以写者可能饿死。
class RWlock
{
void readlock()
{
std::lock_gaurd<std::mutex>(classlock);
if(count==0)
rwlock.lock();
count++;
}
viod readunlock()
{
std::lock_gaurd<std::mutex>(classlock);
count--;
if(count==0)
rwlock.unlock();
}
void writelock()
{
rwlock.lock();
assert(count==0);
}
viod writeunlock()
{
assert(count==0);
rwlock.unlock();
}
private:
std::mutex Classlock,rwlock;
size_t count=0;
}
读优先读写锁:
写优先的读写锁于读优先的读写锁的实现原理是一样的,把上面的代码框架的函数实现对换一下就行。