- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我遇到的情况是有 2 个阻塞队列。首先,我插入一些我执行的任务。当每个任务完成时,它会将一个任务添加到第二个队列,并在其中执行它们。
所以我的第一个队列很简单:我只需检查以确保它不为空并执行,否则我中断():
public void run() {
try {
if (taskQueue1.isEmpty()) {
SomeTask task = taskQueue1.poll();
doTask(task);
taskQueue2.add(task);
}
else {
Thread.currentThread().interrupt();
}
}
catch (InterruptedException ex) {
ex.printStackTrace();
}
}
第二个我执行以下操作,正如您所知,这不起作用:
public void run() {
try {
SomeTask2 task2 = taskQueue2.take();
doTask(task2);
}
catch (InterruptedException ex) {
}
Thread.currentThread().interrupt();
}
您将如何解决这个问题,以便第二个 BlockingQueue 不会在 take() 上阻塞,但仅在它知道没有更多项目要添加时才完成。如果第二个线程可以看到第一个阻塞队列,并检查它是否为空并且第二个队列也为空,那么它会中断,那就太好了。
我也可以使用 Poison 对象,但更喜欢其他东西。
注意:这不是确切的代码,只是我在这里写的一些内容:
最佳答案
听起来好像处理第一个队列的线程知道,一旦队列耗尽,就不会再有任何任务了。这听起来很可疑,但无论如何我都会相信你的话并提出解决方案。
定义 AtomicInteger
对两个线程都可见。将其初始化为正数。
按如下方式定义第一个线程的操作:
Queue#poll()
.Queue#poll()
返回null,调用AtomicInteger#decrementAndGet()
在共享整数上。
AtomicInteger#decrementAndGet()
返回零,通过 Thread#interrupt()
中断第二个线程。 (这处理没有元素到达的情况。)AtomicInteger#incrementAndGet()
在共享整数上,将提取的项目添加到第二个线程的队列中,然后继续循环。按如下方式定义第二个线程的操作:
BlockingQueue#take()
上的循环阻塞.BlockingQueue#take()
抛出InterruptedException
,捕获异常,调用Thread.currentThread().interrupt()
,然后退出循环。AtomicInteger#decrementAndGet()
在共享整数上。
AtomicInteger#decrementAndGet()
返回零,退出循环。在尝试编写实际代码之前,请确保您理解这个想法。约定是第二个线程继续等待队列中的更多项目,直到预期任务的计数达到零。此时,生产线程(第一个线程)将不再将任何新项目推送到第二个线程的队列中,因此第二个线程知道可以安全地停止为其队列提供服务。
当没有任务到达第一个线程的队列时,就会出现奇怪的情况。由于第二个线程仅在处理项目后递减并测试计数,因此如果它永远没有机会处理任何项目,则它永远不会考虑停止。我们使用线程中断来处理这种情况,但代价是第一个线程的循环终止步骤中的另一个条件分支。幸运的是,该分支只会执行一次。
有很多设计可以在这里发挥作用。我只是描述了一种仅引入了一个附加实体(共享原子整数)的方法,但即便如此,它仍然很繁琐。我认为使用毒丸会更干净,尽管我承认这两者都不是 Queue#add()
也不BlockingQueue#put()
接受 null 作为有效元素(由于 Queue#poll()
的返回值约定)。否则很容易将 null 用作毒丸。
关于Java BlockingQueue 在 take() 上阻塞,略有不同,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8720766/
我的理解是1.5加入了callable,runnable接口(interface)保持原样,防止世界末日。为什么我不能实例化 ThreadPoolExecutor (core, max, tu, un
我正在制作一个包含两个线程的应用程序:其中一个向 LinkedBlockingQueue 写入一个值,另一个正在读取。我正在使用 ScheduledExecutorService 在某个时间段内以秒为
我正在尝试 Autowiring 参数化的阻塞队列: @Bean(name = "saveProductQueue") public BlockingQueue saveProductQueue()
我正在实现一个程序,其中主线程将各种消息推送到工作线程,而工作线程将工作结果推送回主线程。 为此,我计划使用两个队列,一个用于推送到工作线程,另一个用于从中拉出。 据我了解,线程会缓存对象,因此如果它
我正在使用 RabbitMQ,它默认为消费者使用 LinkedBlockingQueue 。它有一个阻塞的 nextDelivery() 方法,该方法基本上调用队列上的 take() 。 但是如果在调
我有 n 个生产者线程通过 BlockingQueue 为 1 个消费者线程提供数据。我正在使用 .put 和 .take (后者当 .peek != null 时)。除了明显在传输过程中不可避免的数
我已经实现了一个带有套接字线程池的两人游戏。每个玩家都连接到自己的线程。我按照this添加了一个消息队列系统文章。 问题是消息滞后。第一个玩家的第一个响应会按预期添加到 messageQueue 中。
据我所知,BlockingCollection 使用非繁忙等待,这是对新项目/回调的通知。所以我不明白它是如何阻塞的,但我认为我可能混合了阻塞的线程和阻塞的共享对象访问? 最佳答案 这是一个很好的解释
我的 Android 应用程序有一个长时间运行的后台服务,据我所知,它在应用程序的主线程中运行,因此,任何耗时或阻塞的任务都应移至单独的线程。 现在,情况是这样的,我不明白/困惑: 当我从一个 Act
我在数据库前面使用 LinkedBlockingQueue。一个线程写入队列,另一个线程从队列读取。 我认为两个并发写入是不可能的。但是是否有可能一个线程写入而另一个线程同时从队列中读取呢?如果没有,
我有一个在单个后台线程上处理工作事件的 BlockingQueue。各种线程调用 add 将一些工作添加到队列中,单个后台线程调用 take 获取工作并一次处理一个。最终可能是停止处理工作的时候了,我
我在多线程系统中使用 BlockingQueue,其中同步块(synchronized block)将项目添加到列表中。有时它不会将项目添加到列表中,它遗漏的项目是随机的。我尝试将以下行添加到代码中,
我有以下阻塞队列; final BlockingQueue blockingQueue = new LinkedBlockingQueue(); 在哪里 public class Message
这个问题的标题让我怀疑这是否存在,但仍然: 我感兴趣的是是否有 Java 的 BlockingQueue 的实现,它受大小限制,从不阻塞,而是在尝试入队太多元素时抛出异常。 编辑 - 我将 Block
假设我有 BlockingQueue 并且一些线程被称为 take() 但此时队列是空的。假设我以某种方式知道将来不会有新元素出现在队列中。如何释放那些被称为 take() 的线程等待?谢谢! p
我想要一个线程安全的容器,它会阻止调用者,直到有项目可用为止。项目将以每秒 1000 秒的速度添加到此容器中,但不会以相同的速度排出。因此,我希望容器不允许重复。我围绕 LinkedBlockingQ
我正在使用 BlockingQueue(LinkedBlockingQueue) 在多个线程之间同步数据。请看下图。 主线程是一个生产者,它生产对象,然后将它们放入每个消费者的队列中(线程2-10)。
我有一个容量为 1 的 BlockingQueue。它存储收到的股票的最后价格。价格保留在队列中,直到客户端轮询队列。然后,我有一个名为 getLatestPrice() 的方法,它应该返回股票的最新
我的 Java 代码中使用 BlockingQueue 时存在潜在的竞争条件,我想知道如何修改代码来避免这种情况: private static BlockingQueue ftpQueue = ne
我有一种情况需要 BlockingQueue 上的方法 peekWait。我会将此方法描述为 retrieves but not remove the head of the queue, waiti
我是一名优秀的程序员,十分优秀!