站内搜索: 请输入搜索关键词

当前页面: 开发资料首页Java 专题Java中线程池简单构建

Java中线程池简单构建

摘要: Java中线程池简单构建

杨恒贤(yang_hx@neusoft.com)
现在服务器端的应用程序几乎都采用了“线程池”技术,这主要是为了提高系统效
率。因为如果服务器对应每一个请求就创建一个线程的话,在很短的一段时间内就
会产生很多创建和销毁线程动作,导致服务器在创建和销毁线程上花费的时间和消
耗的系统资源要比花在处理实际的用户请求的时间和资源更多。线程池就是为了尽
量减少这种情况的发生。
下面我们来看看怎么用Java实现一个线程池。一个比较简单的线程池至少应包含线
程池管理器、工作线程、任务队列、任务接口等部分。其中线程池管理器
(ThreadPool Manager)的作用是创建、销毁并管理线程池,将工作线程放入线程池
中;工作线程是一个可以循环执行任务的线程,在没有任务时进行等待;任务队列
的作用是提供一种缓冲机制,将没有处理的任务放在任务队列中;任务接口是每个
任务必须实现的接口,主要用来规定任务的入口、任务执行完后的收尾工作、任务
的执行状态等,工作线程通过该接口调度任务的执行。
一种就是以固定线程数目作为基准,让每一个线程的工作线程都处于无限循环中,
利用Java中基类的nodify()与wait()进行协同工作。
基本思想如下:
在构建线程池的时候创建所有工作线程,并且让所有工作线程开始运行。
public ThreadPool(int nPoolSize) {
if(nPoolSize<=0){
nPoolSize=DEFAULT_POOL_SIZE; }
m_ThreadList=new ArrayList();
m_RunList=new LinkedList();
for(int i=0;i WorkerThread temp=new WorkerThread(i+1);
m_ThreadList.add(temp);
temp.start(); } }
在工作线程的run()方法中用wait()进行等待,当线程处于wait()状态基本不
占用CPU,这样所有工作线程都处于挂起状态,等待任务来唤醒。 实现如下:
while (true) {
synchronized (m_RunList) {
while (m_RunList.isEmpty()) {//任务列表为空则进行等待,否则
运行任务,并在本任务列表里面剔除任务 try {
m_RunList.wait(); }
catch (InterruptedException e) { } }
r = (Runnable) m_RunList.removeFirst();
//System.out.println(m_nThreadID + ":Start");
if (r == null)return; } try {
r.run(); }
catch (Exception e) { } }
以上代码就是一个工作线程主要代码。这个线程永远不会停止,只可能被挂起,或
者运行任务。
明天介绍另一种线程池的实现方法。
http://www.wds.gov.cn/UpImage/200417737.rar
↑返回目录
前一篇: JBuilder9+weblogic7.0完全攻略
后一篇: Java中文识别问题完全解决办法[二] s