PriorityQueue和PriorityBlockingQueue

Lea*_*reM 6 java java.util.concurrent

在这些节目中我应该选择哪一个?为什么?一般来说问题是为什么我应该选择使用PriorityBlockingQueue优先于PriorityQueue.

的PriorityBlockingQueue

import java.util.concurrent.PriorityBlockingQueue;

public class PriorityBlockingQueueExample {

    static PriorityBlockingQueue<String> priorityQueue = new PriorityBlockingQueue<String>();
    public static void main(String[] args) {

        new Thread(){
            public void run(){
                try {
                System.out.println(priorityQueue.take() +" is removed from priorityQueue object");
                } catch (InterruptedException e) {
                    // TODO Auto-generated catch block
                    e.printStackTrace();
                }    
            }
        }.start();
        new Thread(){
            public void run(){
                priorityQueue.add("string variable");
                System.out.println("Added an element to the queue");
            }
        }.start();
    }
}
Run Code Online (Sandbox Code Playgroud)

在这些节目中我应该选择哪一个?为什么?一般来说问题是为什么我应该选择使用PriorityBlockingQueue优先于PriorityQueue.的PriorityQueue

import java.util.PriorityQueue;

public class PriorityQueueTest {

    static PriorityQueue<String> priorityQueue = new PriorityQueue<String>();
    private static Object lock = new Object();
    public static void main(String[] args) {

        new Thread(){
            public void run(){
                synchronized(lock){     
                    try {
                        while(priorityQueue.isEmpty()){lock.wait();}
                            System.out.println(priorityQueue.remove() +" is removed from priorityQueue object");
                            lock.notify();
                    } catch (InterruptedException e) {
                            //  TODO Auto-generated catch block
                            e.printStackTrace();
                    }
                }
            }
        }.start();
        new Thread(){
            public void run(){
                synchronized(lock){
                    priorityQueue.add("string variable");
                    System.out.println("Added an element to the queue");
                    lock.notify();
                }
            }
        }.start();
    }
}
Run Code Online (Sandbox Code Playgroud)

Nic*_*olt 15

一个正常Queue返回null时访问的,如果它是空的,而一个BlockingQueue ,如果队列为空,直到值可用.

您正在使用的队列中的优先级部分仅表示以特定顺序从队列中读取项目(如果它们实现Comparable或根据a,则是自然的Comparator).

通常你可以依赖抽象类型,PriorityQueue或者BlockingQueue.如果您的代码需要了解这两个概念,则可能需要重新思考.

有很多原因可能需要PriorityQueue归结为消息排序.例如,在作业队列中,您可能希望能够优先处理这些作业.这通常表示处理作业的代码应该与订单无关.

如果BlockingQueue您通常在工作线程领域进行排队工作,并且没有工作要做,那么这些线程可能会被阻塞,直到工作可用.就像a的例子一样PriorityQueue,调用代码可能与此无关,但是你可能想要使用某种等待超时并不总是如此.


jsu*_*rls 8

使用JDK 5中的并发包添加了PriorityBlockingQueue,请参阅:http://docs.oracle.com/javase/1.5.0/docs/api/java/util/concurrent/package-summary.html

它基本上是为您在为队列添加通常必要的同步/等待/通知而为PriorityQueue编写的额外代码.因此,添加名称的"阻塞"部分意味着线程将阻塞等待,直到队列中有可用的项目为止.

如果您的应用程序可以在JDK 5或更高版本上运行,我将使用PriorityBlockingQueue.