悲观锁与乐观锁

悲观锁与乐观锁,第1张

悲观锁与乐观锁

悲观锁与乐观锁是针对进程中线程发生抢占的情况。

悲观锁:认为在程序中存在着大量的竞争关系,一旦某个线程抢占成功,资源锁死,不允许其他线程争抢,适用于多进程。

乐观锁:不认为有大量的线程同时争抢一块资源,以版本号为基础进行 *** 作,适用于少量进程。

我们常用的是乐观锁。

区别:

1.悲观锁是当线程拿到资源时,就对资源上锁,并在提交后,才释放锁资源,其他线程才能使用资源。

2.乐观锁是当线程拿到资源时,上乐观锁,在提交之前,其他的锁也可以 *** 作这个资源,当有冲突的时候,并发机制会保留前一个提交,打回后一个提交,让后一个线程重新获取资源后,再 *** 作,然后提交。和git上传代码一样,两个线程都不是直接获取资源本身,而是先获取资源的两个copy版本,然后在这两个copy版本上修改。

3.悲观锁和乐观锁在并发量低的时候,性能差不多,但是在并发量高的时候, 乐观锁的性能远远优于悲观锁。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zaji/5661348.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-12-16
下一篇 2022-12-16

发表评论

登录后才能评论

评论列表(0条)

保存