java 并发 - 锁集合

2021/10/4 14:40:44

本文主要是介绍java 并发 - 锁集合,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!

java 并发 - 锁集合

名称示例
乐观锁
悲观锁
独占锁
共享锁
公平锁new ReentrantLock(true)
非公平锁new ReentrantLock(false)
自旋锁
重入锁synchronized

乐观锁、悲观锁

  • 悲观锁指对 数据被外界修改持保守态度 ,认为数据 很容易就会被其他线 程修改 ,所以在数据被处理前先对数据进行加锁,并在整个数据处理过程中,使数据处于锁定状态
  • 悲观锁的 实 现往往依 靠数据库提供 的锁机制,即在数据库 中 ,在对数据记录操作前给记录加排它锁 。 如果获取锁失败, 则说明数据正在被 其他线程修改 , 当 前 线程 则 等待或者 抛出 异常。 如果 获取锁成功,则对记 录进行操作 ,然 后提交事务后释放排它锁

公平锁、非公平锁

  • 公平锁表示线程获取锁的顺序是按照线程请求锁的时间早晚来决定的,也就是最早请求锁的 线程将最早获取 到锁
  • 非公平锁 则 在运行时闯入,也就是先来不 一 定先得

独占锁、共享锁

根据锁只能被单个线程持有还是能被 多 个线程共同持有,锁可以分为独占锁和 共享锁

重入锁

当一 个线程要获取 一 个被其他线程持有的独占锁时,该线程会被阻塞,那么当 一个程再次获取它自己己经获取的锁时是否会被阻塞呢?如果不被阻塞,那么我们说该锁是可重入的,也就是只要该线程获取了该锁



这篇关于java 并发 - 锁集合的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!


扫一扫关注最新编程教程