返回介绍

java.util.concurrent.locks 类 ReentrantReadWriteLock.WriteLock

发布于 2019-10-04 09:51:52 字数 8592 浏览 958 评论 0 收藏 0

java.lang.Object
  └java.util.concurrent.locks.ReentrantReadWriteLock.WriteLock
所有已实现的接口:
Serializable, Lock
正在封闭类:
ReentrantReadWriteLock

public static class ReentrantReadWriteLock.WriteLock
extends Object
 
implements Lock, Serializable
 

ReentrantReadWriteLock.writeLock() 方法返回的锁定。

另请参见:
序列化表格

构造方法摘要
protectedReentrantReadWriteLock.WriteLock(ReentrantReadWriteLocklock)

子类使用的构造方法

方法摘要
voidlock()

获取写入锁定。

voidlockInterruptibly()

获取写入锁定,除非当前线程被 中断

ConditionnewCondition()

返回一个用来与此 Lock 实例一起使用的 Condition 实例。

StringtoString()

返回标识此锁定及其锁定状态的字符串。

booleantryLock()

仅当写入锁定在调用期间未被另一个线程保持时获取该锁定。

booleantryLock(longtimeout, TimeUnitunit)

如果另一个线程在给定的等待时间内没有保持写入锁定,并且当前线程未被 中断 ,则获取写入锁定。

voidunlock()

试图释放此锁定。

从类 java.lang.Object 继承的方法
clone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, wait

构造方法详细信息

ReentrantReadWriteLock.WriteLock

protected ReentrantReadWriteLock.WriteLock(ReentrantReadWriteLocklock)
子类使用的构造方法
参数:
lock - 外部锁定对象
抛出:
NullPointerException - 如果 lock 为 null

方法详细信息

lock

public void lock()
获取写入锁定。

如果另一个线程既没有保持读取锁定也没有保持写入锁定,则获取写入锁定并立即返回,并将写入锁定保持计数设置为 1。

如果当前线程已经保持写入锁定,则保持计数增加 1,该方法立即返回。

如果该锁定被另一个线程保持,出于线程调度的目的,将禁用当前线程,并且在获得写入锁定之前,该线程将一直处于休眠状态,此时写入锁定保持计数设置为 1。

指定者:
接口 Lock 中的 lock

lockInterruptibly

public void lockInterruptibly()
                       throws InterruptedException
获取写入锁定,除非当前线程被 中断

如果另一个线程既没有保持读取锁定也没有保持写入锁定,则获取写入锁定并立即返回,并将写入锁定保持计数设置为 1。

如果当前线程已经保持此锁定,则将保持计数加 1,该方法立即返回。

如果锁定被另一个线程保持,则出于线程调度目的,禁用当前线程,并且在发生以下两种情况之一以前,该线程将一直处于休眠状态:

  • 写入锁定由当前线程获得;或者
  • 其他某个线程 中断 当前线程。

如果当前线程获得写入锁定,则将锁定保持计数设置为 1。

如果当前线程:

  • 在进入此方法时已经设置了该线程的中断状态;或者
  • 在获取写入锁定的同时被 中断

则抛出 InterruptedException ,并且清除当前线程的已中断状态。

在此实现中,因为此方法是一个显式中断点,所以要优先考虑响应中断,而不是响应锁定的普通获取或重入获取。

指定者:
接口 Lock 中的 lockInterruptibly
抛出:
InterruptedException - 如果当前线程是已中断的。
另请参见:
Thread.interrupt()

tryLock

public boolean tryLock()
仅当写入锁定在调用期间未被另一个线程保持时获取该锁定。

如果另一个线程既没有保持读取锁定也没有保持写入锁定,则获取写入锁定并立即返回 true 值,并将写入锁定保持计数设置为 1。即使已将此锁定设置为使用公平排序策略,但是调用 tryLock() 立即获取锁定(如果有可用的),不管其他线程当前是否正在等待写入锁定。在某些情况下,此“闯入”行为可能很有用,即使它会打破公平性也如此。如果希望遵守此锁定的公平设置,则使用 tryLock(0, TimeUnit.SECONDS) ,它几乎是等效的(它也检测中断)。

如果当前线程已经保持此锁定,则将保持计数加 1,该方法将返回 true

如果锁定被另一个线程保持,则此方法将立即返回 false 值。

指定者:
接口 Lock 中的 tryLock
返回:
如果锁定是自由的并且被当前线程获取,或者当前线程已经保持写入锁定,则返回 true ;否则返回 false

tryLock

public boolean tryLock(longtimeout,
                       TimeUnitunit)
                throws InterruptedException
如果另一个线程在给定的等待时间内没有保持写入锁定,并且当前线程未被 中断 ,则获取写入锁定。

如果另一个线程既没有保持读取锁定也没有保持写入锁定,则获取写入锁定并立即返回 true 值,并将写入锁定保持计数设置为 1。如果为了使用公平的排序策略,已经设置此锁定,并且其他线程都在等待写入锁定,则不会 获取一个可用的锁定。这与 tryLock() 方法相反。如果想使用一个允许闯入公平锁定的定时 tryLock ,那么可以将定时形式和不定时形式组合在一起:

if (lock.tryLock() || lock.tryLock(timeout, unit) ) { ... }

如果当前线程已经保持此锁定,则将保持计数加 1,该方法将返回 true

如果锁定被另一个线程保持,则出于线程调度目的,禁用当前线程,并且在发生以下三种情况之一以前,该线程将一直处于休眠状态:

  • 写入锁定由当前线程获得;或者
  • 其他某个线程 中断 当前线程;或者
  • 已超过指定的等待时间

如果获取了写入锁定,则返回 true 值,并将写入锁定保持计数设置为 1。

如果当前线程:

  • 在进入此方法时已经设置了该线程的中断状态;或者
  • 在获取写入锁定的同时被 中断

则抛出 InterruptedException ,并且清除当前线程的已中断状态。

如果超出了指定的等待时间,则返回值为 false 。如果该时间小于或等于 0,则此方法根本不会等待。

在此实现中,因为此方法是一个显式中断点,所以要优先考虑响应中断,而不是响应锁定的普通获取或重入获取,或者报告所用的等待时间。

指定者:
接口 Lock 中的 tryLock
参数:
timeou - 等待写入锁定的时间
unit - timeout 参数的时间单位
返回:
如果锁定是自由的并且由当前线程获取,或者当前线程已经保持写入锁定,则返回 true ;如果在获取该锁定之前已经到达等待时间,则返回 false
抛出:
InterruptedException - 如果当前线程被中断
NullPointerException - 如果时间单位为 null
另请参见:
Thread.interrupt()

unlock

public void unlock()
试图释放此锁定。

如果当前线程保持此锁定,则将保持计数减 1。如果保持计数现在为 0,则释放该锁定。如果当前线程不是此锁定的持有者,则抛出 IllegalMonitorStateException

指定者:
接口 Lock 中的 unlock
抛出:
IllegalMonitorStateException - 如果当前线程没有保持此锁定。

newCondition

public Condition newCondition()
返回一个用来与此 Lock 实例一起使用的 Condition 实例。

在使用内置监视器锁定时,返回的 Condition 实例支持与 Object 的监视器方法( waitnotifynotifyAll )相同的用法。

  • 如果当调用任何 Condition 方法时没有保持此写入锁定,则抛出 IllegalMonitorStateException 。(因为保持读取锁定是独立于写入锁定的,所以读取锁定将不被检查或受影响。但是,在当前线程已经获取读取锁定时,调用一个条件等待方法实质上一直是错误的做法,因为能够解除阻塞该方法的其他线程将无法获取写入锁定。)
  • 当调用 waiting 条件方法并释放写入锁定时,在它们返回之前,会重新获取写入锁定,并将锁定保持计数恢复到调用该方法时的值。
  • 如果线程在等待时被中断,则等待将终止,并将抛出 InterruptedException ,清除线程的已中断状态。
  • 等待线程按 FIFO 顺序收到信号。
  • 等待方法返回的线程重新获取锁定的顺序与线程最初获取锁定的顺序相同,在默认情况下,未指定此顺序,但对于公平 锁定,它们更倾向于那些等待时间最长的线程。
指定者:
接口 Lock 中的 newCondition
返回:
Condition 对象

toString

public String toString()
返回标识此锁定及其锁定状态的字符串。该状态括在括号中,它包括字符串 "Unlocked" 或字符串 "Locked by",后跟所拥有线程的 Thread.getName()
覆盖:
Object 中的 toString
返回:
标识此锁定及其锁定状态的字符串。

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。
列表为空,暂无数据
    我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
    原文