java 锁记录_java多线程可重入锁的几点记录

1、ReentrantLock

是互斥锁,基于AQS的互斥模式实现,也就是说同时只有一个线程进入临界区,唤醒下一个线程时也只能释放一个等待线程

AQS:AbstractQueuedSynchronizer (队列同步器)

AQS使用一个int类型的成员变量state来表示同步状态,当state>0时表示已经获取了锁,当state = 0时表示

释放了锁。它提供了三个方法(getState()、setState(int newState)、compareAndSetState(int expect,int update))来对同步状态state进行操作,当然AQS可以确保对state的操作是安全的。

通常通过如下代码块,来使用ReenntrantLock保护代码块:

Lock lock = new ReentrantLock();lock.lock();try {// update object state}finally {lock.unlock(); ####一定要在finally中进行锁的释放}

2、java多线程中Object.wait()和Condition.await()是否会释放当前线程锁占有的锁?

得到的结论是会释放:

A monitor is a collection of procedures, variables, and data

structures that are all grouped together in a special kind of module

or package. Processes may call the procedures in a monitor whenever

they want to, but they cannot directly access the monitor's internal

data structures from procedures declared outside the monitor. This

rule, which is common in modern object-oriented languages such as

Java, was relatively unusual for its time, although objects can be

traced back to Simula 67.

Condition的使用:

ArrayBlockingQueue内部,维护了一个定长数组,以便缓存队列中的数据对象,这是一个常用的阻塞队列,除了一个定长数组外,ArrayBlockingQueue内部还保存着两个整型变量,分别标识着队列的头部和尾部在数组中的位置。

76f54346d723b6e3c2ff3a0401de7214.png

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值