Java多线程 Chapter 4 Lock 的使用

Chapter 4 Lock 的使用

4.1 使用ReentrantLock类

import java.util.concurrent.locks.Lock;
import java.util.concurrent.locks.ReentrantLock;
import java.util.concurrent.locks.Condition;
try{
lock.lock()
}
catch(){}

finally{

lock.unlock();}

ReentrantLock lock = new ReentrantLock();

Condition condition = lock.newCondition();

Object Conditino wait() await() wait(long)await(long) nofify() signal notifyAll() signalAll()

4.1.7生产者/消费者 一对一交替打印

4.1.8生产者/消费者 多对多交替打印

4.1.9公平锁和非公平锁

公平锁 锁的顺序按照线程加锁的顺序来分配。即,FIFO原则。 非公平锁 锁的抢占机制,随机获得锁。

一些方法

getHoldCount() 当前线程保持该锁定的个数。不同锁不叠加。

getQueueLength() 正在等待获取此锁定的线程估计数。

getWaitQueueLength(Conditioncondition) 作用是返回等待与此锁定相关的给定条件Condition的线程估计数。

hasQueuedThread() 查询指定线程是否正在等待获取此锁定,

lock.hasQueuedThread(threadA)

hasQueuedThreads()查询是否有线程在等待获取此锁定。

hasWaiters(Conditioncondition) 查询是否有线程在等待与此锁定有关的conditioin条件。

isFair() 判断是否公平锁

isHeldByCurrentThread()查询当前线程是否保持此锁定。

isLocked() 查询此锁定是否由任意线程保持。

lockInterruptibly()线程未中断,等待获取锁。等待过程中,线程中断出现异常。

tryLock() 不等待获取锁。能获得锁就获得锁,不能就往下执行。

awaitUninterruptibly()等待遇到中断不会抛出异常,会继续等。中断时获得锁,会体现中断效果。

awaitUntil(Time)

4.1.16

Condition 实现顺序执行。

4.2 使用ReentrantReadWriteLock 类

读读共享 其他组合互斥。

lock.readLock().lcok()lock.readLock().unlock() lock.writeLock().unlcok() lock.writeLock

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值