- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
在Java中,ReentrantLock.lock()
和ReetrantLock.unlock()
是否使用与synchronized()
相同的锁定机制?
我的猜测是“不”,但我希望是错误的。
例子:
假设线程 1 和线程 2 都可以访问:
ReentrantLock lock = new ReentrantLock();
线程 1 运行:
synchronized (lock) {
// blah
}
线程 2 运行:
lock.lock();
try {
// blah
}
finally {
lock.unlock();
}
假设线程 1 先到达它的部分,然后在线程 1 完成之前线程 2:线程 2 会等待线程 1 离开 synchronized()
block ,还是会继续运行?
最佳答案
不,线程 2 可以 lock()
即使线程 1 在同一 lock
上同步
。这就是documentation不得不说:
Note that Lock instances are just normal objects and can themselves be used as the target in a synchronized statement. Acquiring the monitor lock of a Lock instance has no specified relationship with invoking any of the lock() methods of that instance. It is recommended that to avoid confusion you never use Lock instances in this way, except within their own implementation.
关于java - 将 synchronized() 与 ReentrantLock.lock() 混合使用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/2901079/
ReentrantLock 在创建 Lock 对象时提供 boolean fair 标志。 公平:真实 线程根据其等待的时间来访问临界区。 公平:假 没有为线程提供临界区的具体策略。 下面是我的代码:
我是 Java 新手。我只是在尝试线程,我想创建类似线程池的东西(如果这实际上是我正在做的事情......)。 基本上,我有一个 while 循环,它会触发线程,直到仍然有任务要执行&&,同时最大并发
CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界. 这篇CFSDN的博客文章详解java并发之重入锁-ReentrantLock由作者收集整理,如果
有谁知道方法acquire()和release()(java.util.concurrent.Semaphore)和await () 和 signal (new ReentrantLock().new
我一直在做一个关于 Java 多线程的学校作业。我遇到的一个任务是,我们需要在不同的组中创建多个线程,一旦每个组中有 4 个线程,只有这样才能释放它们协同工作,否则它们必须被搁置/等待。例如: 线程
我试图了解 Java 中 ReentrantLock 的内部工作原理。 我创建了一个示例,例如:- package com.thread.trylock; import java.util.concu
问题出在哪里? ReentrantLock 未显示预期结果。两个线程同时执行,而不是等待一个线程。 class MyThread2 extends Thread{ String name;
我正在为 Android 2.2 开发,对 ReentrantLocks 的工作原理有点困惑。以下代码是否会抛出 IllegalMonitorStateException?我问是因为我看不出它是如何做
我们的应用程序在 WebLogic 12c 中运行,正在从队列系统中检索消息,我们从中检索消息的队列配置为 FIFO。我们使用 Spring 来配置检索功能,并且容器 (org.springframe
我使用线程(等待和通知)功能创建了一个生产者消费者程序。代码是—— /** * Message.java ( Common object ) */ package threads; import
假设我有一个服务器有多个线程共享一个数据实例的引用。快速例如, edit1:为可读性更新 public void main() { Data data = new Data(); Reentran
我不明白为什么代码不能正常工作。问题是 ReentrantLock 没有锁定 ThreadClass.run() 中的方法调用 Resource-class哪些方法被假定为在ThreadClass中被
重入锁 void a() { lock.lock(); //got intrinsic lock System.out.println(Thread.currentThread(
我正在尝试在多线程上实现可重入锁,但由于某种原因,同一个线程解锁然后再次锁定导致始终运行相同的线程,因此运行相同的操作。 下面是线程产生的代码 IntStream.range(0,(NUMBER_OF
我有两个方法都由不同的线程运行,其中一个方法我不想在另一个方法被调用时运行。这就是我选择使用锁的原因 @Override public synchronized void doSomething(in
下面是线程被锁定之前和线程解锁之后的所有信息。我正在使用 ReentrantLock 的 lock() 和 unlock() 方法。然而,虽然某个进程已经解锁了该锁,但另一个进程却无法锁定同一个锁。
ReentrantLock 允许线程多次锁定某个资源, 这在执行/效率/功能方面有何好处? 请参阅此链接,https://www.geeksforgeeks.org/reentrant-lock-ja
当我在互联网上阅读一些并发代码示例时,我发现了这个(2个银行帐户之间的转账操作): class Account { double balance; int id; pub
我有一个 ReentrantLock,一堆操作正在锁定它,它是使用 new ReentrantLock(true) 公平创建的。有没有办法让线程“闯入”锁并在锁释放后但在任何其他线程之前获取它? 我考
我有一个带有静态变量的类,多个线程都会有这个类的实例。 我关心的静态变量是一个Thread,它将从队列中弹出一条消息并通过电子邮件发送,直到队列为空。每次将消息添加到队列时,我都会检查线程是否还活着。
我是一名优秀的程序员,十分优秀!