- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有多个线程从同一个队列写入和读取。我正在使用并发链接队列。任何线程都可以将一个元素添加到队列中,任何其他线程都可以轮询一个元素并对其进行处理。我的问题是,如果队列为空,我想让正在轮询队列的线程等待,直到某个元素被其他线程添加到它,如果所有线程都在等待,即没有线程正在写入,则整个进程应该退出。我正在使用它来列出目录及其子目录中的所有文件#faster scan。
以下是代码片段 1:
{
私有(private)队列 dList = new ConcurrentLinkedQueue();
/* 一些处理代码 */
public void Run
{
/* some processing code */
while(dName == null)
{
try{
synchronized(dList){
dList.wait();
}
} catch(InterruptedException e){}
dName = dList.poll();
}
/* some processing code */
{
dList.add(item);
synchronized(dList){
dList.notifyAll();
}
}
}
上面的代码对吗?它是否一直做我想做的事。虽然程序运行良好,但我不明白线程是如何退出的,因为我没有提到任何退出条件。
在ConcurrentLinkedQueue上使用synchronized对吗?这也适用于大目录吗?编辑1:使用LinkedBlockingQueue,但是当所有线程都处于等待状态意味着不再需要扫描目录时如何退出?它会使用一个静态变量,增加它并检查它是否等于 numberofthreads,然后退出。它有效还是有更好的解决方案?
编辑 2:谢谢你们。退出线程由AtomicInteger解决。如果所有线程都在等待队列,那么它们的 AtomicInteger 递增,如果 AtomicInteger 等于线程数则中断;
最佳答案
您所描述的是阻塞。您最好使用像 ArrayBlockingQueue
这样专门执行此操作的数据结构,而不是自己创建一个。它执行并发,但也有阻塞方式来访问队列,强制运行的线程等待直到有一个项目要获取。使用所有必需的锁定等。您还可以使用 LinkedBlockingQueue
https://docs.oracle.com/javase/7/docs/api/java/util/concurrent/ArrayBlockingQueue.html https://docs.oracle.com/javase/7/docs/api/java/util/concurrent/LinkedBlockingQueue.html
这使得您可以拥有消费者线程和生产者线程,并且您不必自己进行任何锁定或同步。您只需使用 take() 或执行 put(item) ,如果没有空间放置该项目或没有项目可取,线程将等待。它为您进行相关的锁定和解锁。并且只有当它不能真正拿到元素或把它放在那里时才会等待。还有会超时的操作等。
new Thread(new Runnable() {
@Override
public void run() {
while (true) {
if (Thread.currentThread().isInterrupted()) return;
try {
File file = blockingqueue.take();
} catch (InterruptedException ignored) {
return;
}
processFile(file);
}
}
}).start();
您实际上不必同步 ConcurrentLinkedQueue,它是线程安全的。你正在做的是实现阻塞。有很多事情可以解释这应该如何完成。无论您等待和通知什么对象(尽管必须是同一个对象),都适用相同的规则。
关于java - 多线程写入和多线程读取的 ConcurrentLinkedQueue 的并发问题。 #快速目录扫描,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41917711/
我在迭代时更新ConcurrentLinkedQueue。理论上,该队列上的迭代器在到达队列末尾之前不应停止。但是,在我的程序中(如下所示),迭代器在迭代队列的初始状态(没有更新)后停止。我应该怎样解
假设我有 ConcurrentLinkedQueue 类型的类字段。此类的一些方法向该队列提供新元素。还有一些其他方法需要轮询此时队列中的所有元素。 我无法在循环中使用poll(),因为在循环尚未完成
作为我项目的一部分,我需要创建一个包含固定数量线程的线程池。每当线程分配给不同的进程时,我也需要与线程一起分配那么多 session 。我想使用 ConcurrentLinkedQueue (固定大小
我正在开发一个项目,其中我将某些数据包添加到队列中以便稍后处理(接下来的 600 毫秒滴答处理队列中的所有数据包)。 但是,我目前遇到了麻烦,因为当在同一周期中接收到两个数据包时,队列的行为非常奇怪。
我正在开发一个 Andoid 应用程序,它由在后台运行的服务和连接到该服务的一些 Activity 组成。该服务在它自己的进程上运行。 我的Service主要有3个类:ServiceMain、Serv
您能否澄清一下,我们是否需要使用显式同步或锁来使用 ConcurrentLinkedQueue?我特别想知道以下 ConcurrentLinkedQueue 方法是否需要同步调用。 添加 清除 尺寸
当前正在 for 循环中处理的元素是队列的头部吗? private Queue users = new ConcurrentLinkedQueue(); for(User u : users){
我想知道在什么情况下 ConcurrentLinkedQueue 无法从其集合中删除元素。该项目存在,它在集合内但调用 SomeConcurrentLinkedQueue.remove(item) 不
我想实现一个监视器队列,两个不相关的线程可以共享它的附加内容。在这种情况下,仅使用 ConcurrentLinkedQueue 就足够了,还是我应该采取不同的做法?我想实现 Activity 对象设计
我想使用 ConcurrentLinkedQueue在原子中lock-free方式: 多个并发线程将事件插入队列,其他线程将处理它们。队列未绑定(bind),我不希望任何线程等待或被锁定。然而,阅读部
阅读 Java's ConcurrentLinkedQueue Docs ,我想知道为什么实现无法存储大小: Beware that, unlike in most collections, the
我想使用 java.util.ConcurrentLinkedQueue 作为 Servlet 的非持久队列。这是该类(class)的 javadoc 中的简介。 An unbounded threa
如何在 Java 中使用 ConcurrentLinkedQueue? 使用这个LinkedQueue,我需要担心队列中的并发吗?还是我只需要定义两个方法(一个从列表中检索元素,另一个将元素添加到列表
当我们使用诸如 ConcurrentLinkedQueue 甚至一些 BlockingQueue 之类的内置队列之一时,单个调用是原子的并且保证是线程安全的。 但是当对 API 的 5 次调用中,有
我有一个工作线程,它应该迭代 ArrayList 。其他线程可以添加和删除对象(队列)。但ArrayList不是线程安全的。使用 ConcurrentLinkedQueue 可以吗?而不是ArrayL
我有以下代码: Queue localMsgQueue; //inside the constructor localMsgQueue = new ConcurrentLinkedQueue(); p
我广泛使用 ConcurrentLinkedQueue 进行多消耗任务排队,以前从未遇到过此问题。场景如下: 用一些任务填充我的队列 运行多个线程(在本例中为 2 个),这些线程将从队列中池化任务 当
我的线程永远运行并在 ConcurrentLinkedQueue#peek() 之后调用 ConcurrentLinkedQueue#poll()。 但在某些情况下,线程似乎挂起。我知道这有点含糊但是
我目前正在开发一个 Java 项目,该项目在原始数据包通过网络时对其进行处理。数据由libpcap读入,然后每个数据包放入一个byte[],然后放入一个ConcurrentLinkedQueue,线程
使用ConcurrentLinkedQueue时出现以下错误: Error : local variables referenced from a lambda expression must be
我是一名优秀的程序员,十分优秀!