乐观锁、悲观锁、互斥锁、读写锁

乐观锁和悲观锁是两种不同的锁机制,用于在多线程环境下解决资源竞争问题。互斥锁和读写锁是两种常见的锁类型,它们都可以用来实现乐观锁或悲观锁。

乐观锁

是一种无锁机制,它假设在多线程环境下对共享资源的操作不会发生冲突,因此在执行操作时不会加锁。当操作完成后,会检查是否发生了冲突,如果发生了冲突,则重试操作直到成功为止。乐观锁通常用于冲突概率较低的场景,因为它的重试机制会带来额外的开销。

悲观锁

是一种有锁机制,它假设在多线程环境下对共享资源的操作很可能发生冲突,因此在执行操作之前会加锁,操作完成后释放锁。悲观锁通常用于冲突概率较高的场景,因为它能够有效地避免冲突。

互斥锁

(也称为独占锁)是一种锁类型,它只允许一个线程对共享资源进行操作。当一个线程获取了互斥锁之后,其他线程就无法对这个资源进行操作,直到当前线程释放了锁。互斥锁可以用来实现悲观锁,在多线程环境下保证同一时刻只有一个线程对共享资源进行操作。

读写锁

是一种锁类型,它既允许多个线程同时对共享资源进行读操作,也允许单个线程对共享资源进行写操作。当多个线程同时读取共享资源时,可以同时获取读锁;当有一个线程要写入共享资源时,需要获取写锁,这时其他线程就不能对共享资源进行读或写操作,直到当前线程释放写锁。读写锁可以用来实现乐观锁,在多线程环境下提高读操作的并发性

互斥锁和读写锁的区别在于,互斥锁只允许一个线程对共享资源进行操作,而读写锁则允许多个线程同时对共享资源进行读操作,但只允许单个线程对共享资源进行写操作。这意味着,互斥锁会对共享资源的读写操作都进行加锁,而读写锁则可以将读操作和写操作分开进行加锁,从而提高了读操作的并发性。

在实现上,互斥锁通常是通过二元信号量或原子操作来实现的。二元信号量是一种同步机制,它可以用来控制资源的访问,允许一个线程获取资源,同时阻塞其他线程的访问。原子操作是指在计算机内存中的操作,其不可被中断,能够保证操作的原子性。

读写锁通常是通过读者-写者锁来实现的。读者-写者锁是一种同步机制,它可以用来控制对共享资源的读写访问。当有多个线程同时读取共享资源时,可以同时获取读锁;当有一个线程要写入共享资源时,需要获取写锁,这时其他线程就不能对共享资源进行读或写操作,直到当前线程释放写锁。

总的来说,乐观锁是一种无锁机制,它通过重试来避免冲突,适用于冲突概率较低的场景。悲观锁是一种有锁机制,它通过加锁来避免冲突,适用于冲突概率较高的场景。互斥锁是一种常见的锁类型,它只允许一个线程对共享资源进行操作,适用于悲观锁的场景。读写锁是另一种常见的锁类型,它既允许多个线程同时对共享资源进行读操作,也允许单个线程对共享资源进行写操作,适用于乐观锁的场景。

相关推荐
随心Coding8 分钟前
【MySQL】存储引擎有哪些?区别是什么?
数据库·mysql
m0_748237051 小时前
sql实战解析-sum()over(partition by xx order by xx)
数据库·sql
dal118网工任子仪2 小时前
61,【1】BUUCTF WEB BUU XSS COURSE 11
前端·数据库·xss
萌小丹Fighting3 小时前
【Postgres_Python】使用python脚本批量创建和导入多个PG数据库
数据库
青灯文案13 小时前
Oracle 数据库常见字段类型大全及详细解析
数据库·oracle
羊小猪~~4 小时前
MYSQL学习笔记(四):多表关系、多表查询(交叉连接、内连接、外连接、自连接)、七种JSONS、集合
数据库·笔记·后端·sql·学习·mysql·考研
村口蹲点的阿三6 小时前
Spark SQL 中对 Map 类型的操作函数
javascript·数据库·hive·sql·spark
暮湫7 小时前
MySQL(1)概述
数据库·mysql
fajianchen8 小时前
记一次线上SQL死锁事故:如何避免死锁?
数据库·sql
chengpei1478 小时前
实现一个自己的spring-boot-starter,基于SQL生成HTTP接口
java·数据库·spring boot·sql·http