Java.util.concurrent包学习(一) BlockingQueue接口
JDK1.7
BlockingQueue<E>接口 (extends Queue<E>)
所有父接口:Collection<E>,Iterable<E>,Queue<E>
所有子接口:BlockingDeque<E>,TransferQueue<E>
所有实现该接口的类:ArrayBlockingQueue,DelayQueue,LinkedBlockingQueue,LinkedTransferQueue,PriorityBlockingQueue,SynchronousQueue,LinkedBlockingDeque
一种支持操作等待的队列,取元素时如果队列为空则等待队列变为非空,放元素时如果队列满则等待队列有可用空间。元素出入方式为FIFO。
BlockingQueue的方法有四种形式构成:见下表:
| Throws exception | Special value | Blocks | Times out | |
| Insert | add(e) | offer(e) | put(e) | offer(e,time,unit) | 
| Remove | remove() | poll() | take() | poll(time,unit) | 
| Examine | element() | peek() | not applicable | not applicable | 
BlockingQueue不接受null值元素,通过add,offer,put方法试图添加null值会抛NullPointerException. 因为null值是用来指明poll方法失败的。
BlockingQueue有容量界限,任何时候都可以通过remainingCapacity值查看可用容量,当已用容量超过remainingCapacity值时,额外的元素不能无阻塞的添加到队列中。
没有内在容量限制的队列,remainingCapacity会返回Integer.MAX值。
BlockingQueue实现类设计初衷主要用于生产者-消费者队列,但是也支持了Collection接口,因此,可以使用remove(e)方法从队列中移除任何元素。但是需要注意的是,
这种操作并不高效,偶尔才使用到。
BlockingQueue实现类都是线程安全(Thread-safe)的,所有排队方法都通过内部锁或者其他并发控制实现了原子操作。但是,像集合堆的操作,addAll(),containsAll(),
retainAll(),removeAll(),实现类中没有特殊规定的话就没有必要实现原子操作,所以,当使用addAll(c)可能会存在添加一部分之后操作失败了。
代码示例,基于典型的生产者-消费者场景。BlockingQueue可以安全的被用于多个生产者和多核
 class Producer implements Runnable {
    private final BlockingQueue queue;
    Producer(BlockingQueue q) {
          queue = q;
    }
    public void run() {
      try {
        while (true) {
            queue.put(produce());
        }
      } catch (InterruptedException ex) { ...}
    }
    Object produce() { ... }
  }
  class Consumer implements Runnable {
    private final BlockingQueue queue;
    Consumer(BlockingQueue q) {
          queue = q;
    }
    public void run() {
      try {
        while (true) {
            consume(queue.take());
         }
      } catch (InterruptedException ex) { ... }
    }
    void consume(Object x) { ... }
  }
  public class Main{
    public static void main(String[] args) {
      BlockingQueue q = new SomeQueueImplementation();
      Producer p = new Producer(q);
      Consumer c1 = new Consumer(q);
      Consumer c2 = new Consumer(q);
      new Thread(p).start();
      new Thread(c1).start();
      new Thread(c2).start();
    }
  }
Java.util.concurrent包学习(一) BlockingQueue接口的更多相关文章
- java.util.concurrent包学习笔记(一)Executor框架
		
类图: 其实从类图我们能发现concurrent包(除去java.util.concurrent.atomic 和 java.util.concurrent.locks)中的内容并没有特别多,大概分为 ...
 - java.util.concurrent包API学习笔记
		
newFixedThreadPool 创建一个固定大小的线程池. shutdown():用于关闭启动线程,如果不调用该语句,jvm不会关闭. awaitTermination():用于等待子线程结束, ...
 - java.util.concurrent包
		
在JavaSE5中,JUC(java.util.concurrent)包出现了 在java.util.concurrent包及其子包中,有了很多好玩的新东西: 1.执行器的概念和线程池的实现.Exec ...
 - 【并发编程】【JDK源码】JDK的(J.U.C)java.util.concurrent包结构
		
本文从JDK源码包中截取出concurrent包的所有类,对该包整体结构进行一个概述. 在JDK1.5之前,Java中要进行并发编程时,通常需要由程序员独立完成代码实现.当然也有一些开源的框架提供了这 ...
 - 高并发编程基础(java.util.concurrent包常见类基础)
		
JDK5中添加了新的java.util.concurrent包,相对同步容器而言,并发容器通过一些机制改进了并发性能.因为同步容器将所有对容器状态的访问都串行化了,这样保证了线程的安全性,所以这种方法 ...
 - 线程并发线程安全介绍及java.util.concurrent包下类介绍
		
线程Thread,在Java开发中多线程是必不可少的,但是真正能用好的并不多! 首先开启一个线程三种方式 ①new Thread(Runnable).start() ②thread.start(); ...
 - 《java.util.concurrent 包源码阅读》 结束语
		
<java.util.concurrent 包源码阅读>系列文章已经全部写完了.开始的几篇文章是根据自己的读书笔记整理出来的(当时只阅读了部分的源代码),后面的大部分都是一边读源代码,一边 ...
 - 《java.util.concurrent 包源码阅读》04 ConcurrentMap
		
Java集合框架中的Map类型的数据结构是非线程安全,在多线程环境中使用时需要手动进行线程同步.因此在java.util.concurrent包中提供了一个线程安全版本的Map类型数据结构:Concu ...
 - 《java.util.concurrent 包源码阅读》13 线程池系列之ThreadPoolExecutor 第三部分
		
这一部分来说说线程池如何进行状态控制,即线程池的开启和关闭. 先来说说线程池的开启,这部分来看ThreadPoolExecutor构造方法: public ThreadPoolExecutor(int ...
 
随机推荐
- Flip Game                                                       分类:            POJ             2015-06-15 14:59    22人阅读    评论(0)    收藏
			
Flip Game Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 33519 Accepted: 14642 Descr ...
 - cmake用法(转)
			
转自:http://blog.csdn.net/dbzhang800/article/details/6314073 新工作中使用到了cmake,所以找点资料学习一下,这篇讲的确实不错,转过来保存一下 ...
 - HTML5之结构元素
			
1:文档结构元素 1.1 文章语义 -- article.header和footer元素 article元素在页面中用来表示结构完整且独立的内容部分,如论坛的一个帖子,杂志或者报纸的一篇文章. ar ...
 - Javascript正则表达式笔记
			
一.字符类 将单独的直接字符放进[]内,就组成了字符类.一个字符类和它所包含的任何字符都匹配. 例如:/[abc]/ 与abc三个字母的任意一个匹配. 同时,还可以定义否定字符类.利用^字符.例如:/ ...
 - response.setContentType()的参数说明
			
response.setContentType()的参数说明 <meta http-equiv="Content-Type" content="text/html; ...
 - PostGIS_导入shp格式的数据
			
1.导入shp到PostGIS 开启PostGIS shp Loader,如下图: 打开View connection details....输入连接数据库的参数,如下: 连接成功后,点击Add Fi ...
 - UIView如何管理它的子视图
			
UIView提供了很多建立和管理视图的方法. 1.添加视图 insertSubview:atIndex: //放在子视图数组的具体索引位置 insertSubview:aboveSubview: ...
 - xtrabackup 安装、备份、还原及错误处理 教程
			
xtrabackup 是MYSQL的一个备份软件 Xtrabackup是一个对InnoDB做数据备份的工具,支持在线热备份(备份时不影响数据读写),是商业备份工具InnoDB Hotbackup的一个 ...
 - 【CSS】最全的CSS浏览器兼容问题
			
CSS对浏览器的兼容性有时让人很头疼,或许当你了解当中的技巧跟原理,就会觉得也不是难事,从网上收集了IE7,6与Fireofx的兼容性处理方法并 整理了一下.对于web2.0的过度,请尽量用xhtml ...
 - SQL GUID和自增列做主键的优缺点
			
我们公司的数据库全部是使用GUID做主键的,很多人习惯使用int做主键.所以呢,这里总结一下,将两种数据类型做主键进行一个比较. 使用INT做主键的优点: 1.需要很小的数据存储空间,仅仅需要4 by ...