Executor线程,线程池
来源:互联网 发布:iphone画图软件 编辑:程序博客网 时间:2024/05/01 13:18
Executor 最近用了一次,简单记录下。
Executor 是 java5 下的一个多任务并发执行框架(Doug Lea),可以建立一个类似数据库连接池的线程池来执行任务。这个框架主要由三个接口和其相应的具体类组成。Executor、 ExecutorService 和 ScheduledExecutorService 。
1 、 Executor 接口:是用来执行 Runnable 任务的;它只定义一个方法- execute(Runnable command);执行 Ruannable 类型的任务。
2 、 ExecutorService 接口: 继承Executor接口,提供了执行Callable任务和中止任务执行的服务。
3 、 ScheduledExecutorService 接口:继承 ExecutorService 接口,提供了按排程执行任务的服务。
4 、 Executors 类:为了方便使用, 建议使用 Executors的工具类来得到 Executor 接口的具体对象。
Executors 类有几个重要的方法,在这里简明一下:
1 、 callable(Runnable task): 将 Runnable 的任务转化成 Callable 的任务
2 、 newSingleThreadExecutor(): 产生一个 ExecutorService 对象,这个对象只有一个线程可用来执行任务,若任务多于一个,任务将按先后顺序执行。
3 、 newCachedThreadPool(): 产生一个 ExecutorService 对象,这个对象带有一个线程池,线程池的大小会根据需要调整,线程执行完任务后返回线程池,供执行下一次任务使用。
4 、 newFixedThreadPool(int poolSize): 产生一个 ExecutorService 对象,这个对象带有一个大小为 poolSize 的线程池,若任务数量大于 poolSize ,任务会被放在一个 queue 里顺序执行。
5 、 newSingleThreadScheduledExecutor(): 产生一个 ScheduledExecutorService 对象,这个对象的线程池大小为 1 ,若任务多于一个,任务将按先后顺序执行。
6 、 newScheduledThreadPool(int poolSize): 产生一个 ScheduledExecutorService 对象,这个对象的线程池大小为 poolSize ,若任务数量大于 poolSize ,任务会在一个 queue 里等待执行 。
有关Executor框架其它类的说明请参看JAVA 5 的 API文档
- Executor线程,线程池
- Executor线程池实例
- 线程池与Executor
- Executor线程池
- Executor线程池解析
- Executor线程池扩展
- java线程池Executor
- Executor和线程池
- Java 线程池(Executor)
- Java 线程池-Executor
- 多线程五---------线程池 Executor 管理线程
- 线程 线程池 Executor框架 读笔
- 线程并发六:线程池--Executor框架
- 线程池Executor与ExecutorService
- Java 线程池(一)---Executor
- Executor线程池提交任务
- Executor框架的线程池
- Executor框架与线程池
- 一天的节奏
- while循环的二义性(zhao4zhong1 )
- 选择排序
- Solr介绍
- 一步一步写算法(之链表排序)
- Executor线程,线程池
- 用Rakefile管理工程
- 链表的排序
- Nand flash driver
- Sgu 114 Telecasting station
- jQuery:1.5.4.1,表格变色(第一行是奇数)
- java 解析ip
- 安装和使用花生壳(linux)
- js编码解码一个蛮有意思的事