java 多线程中常用的锁

本文介绍了Java多线程中常见的锁机制,包括synchronized、object.wait/notify、读写锁、Condition、ReentrantLock、Semaphore、CountDownLatch、CyclicBarrier以及LockSupport,详细阐述了它们的作用和使用场景,特别是对于并发控制的重要性。
摘要由CSDN通过智能技术生成

1.synchronized (同步)

2.object.wait() object.notify()  (配合synchronized使用)

3.readWriteLock(读写锁)

 
非阻塞阻塞
阻塞阻塞

 

注:读操作次数远大于写操作,读写锁优势最大

4.condition (配合lock使用 类似 object.wait)

 

5.reentrantlock(重入)

 reentrantlock 重要方法:

lock():获得锁,如果锁被占用,等待

lockInterruptibly():获取锁,单优先响应中断.(避免死锁)

tryLock():尝试获取锁,成功返回true,否则返回false.(避免死锁)

tryLock(long time,timeUnit unit):在给定时间内获取锁.(避免死锁)

unlock():释放锁

6.信号量 Semaphore

  指定某个资源可以多少个线程可以同时访问 (初始化指定信号量的准入数)

7.倒计时器 countDownLatch

让某一个线程等待直到倒计时结束,在开始执行。(初始化指定次数)

8.循环栅栏 cyclicBarrier

9.线程阻塞 LockSupport

  弥补了Thread.suspend()方法 resume() 在前发生导致线程无法继续执行,wait()相比不需要或许对象锁

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值