BlockingQueue的不同实现的应用场景

 根据不同的需要BlockingQueue有4种具体实现:
(1)ArrayBlockingQueue:规定大小的BlockingQueue,其构造函数必须带一个int参数来指明其大小。其所含 的对象是以FIFO(先入先出)顺序排序的。 
(2)LinkedBlockingQueue:大小不定的BlockingQueue,若其构造函数带一个规定大小的参数,生成的 BlockingQueue有大小限制,若不带大小参数,所生成的BlockingQueue的大小由Integer.MAX_VALUE来 决定。其所含的对象是以FIFO(先入先出)顺序排序的。
LinkedBlockingQueue和ArrayBlockingQueue比较起来,它们背后所用的数据结构不一样,
  导致LinkedBlockingQueue的数据吞吐量要大于ArrayBlockingQueue,但在线程数量很大时其性能的可预 见性低于ArrayBlockingQueue。 
(3)PriorityBlockingQueue:类似于LinkedBlockingQueue,但其所含对象的排序不是FIFO,而是依据对象的自 然排序顺序或者是构造函数所带的Comparator决定的顺序。 
(4)SynchronousQueue:特殊的BlockingQueue,对其的操作必须是放和取交替完成的。

你可能感兴趣的:(BlockingQueue)