在多个线程上同步Java中的队列

我理解同步的概念,但我现在确定它为什么以这种方式实现,所以我需要一点帮助:

我有2个帖子:

PeriodicalThread将定期接收数据(假设每5秒)并将其放入队列中(目前使用arraydeque,但我不知道其他任何Queue实现是否会更好)

Proccessthread将不断检查队列以查看它是否为空.如果它不为空,它将处理数据(FIFO).

所以,起初我的实现将是:

// Both threads are inner class so they have access to Queue

private Queue queue;
private boolean isReadyToProccess;


class PeriodicalThread extends Thread {
    public void run() {
        while(true) {
           if(isNewDataAvailable) {
                // create Data object
                queue.add(data);
           }
        }
    }
}

class Processthread extends Thread {
    public void run() {
        while(true) {
           if(!queue.isEmpty() && isReadyToProccess) {
               Data data = queue.poll();
               processData(data);
           }
        }
    }
}

private void processData(Data data) {
    // this method send data over network,and the server response callback
    // changes isReadyToProcess value to true.
}

然后当想要处理同步时,我不知道我是否应该使用一个锁对象(以及它是如何实现的),或者是否已经存在一个线程安全的包Queue实现(因为add()和poll( ) 方法)

编辑:我忘了标志isReadyToProcess指示下一个队列数据对象是……好,准备好进行处理.此标志也应同步.

解决方法

arraydeque不支持并发.相反,使用支持并发工作的真实队列,如 BlockingQueue及其在java.util.concurrent包中的一个实现.我建议使用 LinkedBlockingQueue.

如果您需要在线程之间共享标志,最好使用AtomicBoolean而不是手动同步基本布尔字段.

注意:如果您将使用并发进程,最好使用已支持锁定和同步开箱即用的java.util.concurrent程序包提供的类.

相关文章

HashMap是Java中最常用的集合类框架,也是Java语言中非常典型...
在EffectiveJava中的第 36条中建议 用 EnumSet 替代位字段,...
介绍 注解是JDK1.5版本开始引入的一个特性,用于对代码进行说...
介绍 LinkedList同时实现了List接口和Deque接口,也就是说它...
介绍 TreeSet和TreeMap在Java里有着相同的实现,前者仅仅是对...
HashMap为什么线程不安全 put的不安全 由于多线程对HashMap进...