java多线程设计模式详解之五

本文详细介绍了线程池的实现与管理机制,包括如何动态增加和减少线程数,以及通过`currentStatus()`方法实时监控线程状态。通过在主函数中模拟任务分配与线程创建,展示了线程池在实际应用中的高效性和灵活性。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

最后是ThreadPool,负责管理所有的服务器线程,还可以动态增加和减少线程数:
  
  package com.crackj2ee.thread;
  import java.util.*;
  public class ThreadPool extends ThreadGroup {
  private List threads = new LinkedList();
  private TaskQueue queue;
  public ThreadPool(TaskQueue queue) {
  super("Thread-Pool");
  this.queue = queue;
  }
  public synchronized void addWorkerThread() {
  Thread t = new WorkerThread(this, queue);
  threads.add(t);
  t.start();
  }
  public synchronized void removeWorkerThread() {
  if(threads.size()>0) {
  WorkerThread t = (WorkerThread)threads.remove(0);
  t.shutdown();
  }
  }
  public synchronized void currentStatus() {
  System.out.println("-----------------------------------------------");
  System.out.println("Thread count = " + threads.size());
  Iterator it = threads.iterator();
  while(it.hasNext()) {
  WorkerThread t = (WorkerThread)it.next();
  System.out.println(t.getName() + ": " + (t.isIdle() ? "idle" : "busy"));
  }
  System.out.println("-----------------------------------------------");
  }
  }
  
  currentStatus()方法是为了方便调试,打印出所有线程的当前状态。
  
  最后,Main负责完成main()方法:
  
  package com.crackj2ee.thread;
  public class Main {
  public static void main(String[] args) {
  TaskQueue queue = new TaskQueue();
  ThreadPool pool = new ThreadPool(queue);
  for(int i=0; i<10; i++) {
  queue.putTask(new CalculateTask());
  queue.putTask(new TimerTask());
  }
  pool.addWorkerThread();
  pool.addWorkerThread();
  doSleep(8000);
  pool.currentStatus();
  pool.addWorkerThread();
  pool.addWorkerThread();
  pool.addWorkerThread();
  pool.addWorkerThread();
  pool.addWorkerThread();
  doSleep(5000);
  pool.currentStatus();
  }
  private static void doSleep(long ms) {
  try {
  Thread.sleep(ms);
  }
  catch(InterruptedException ie) {}
  }
  }
  
  main()一开始放入了20个Task,然后动态添加了一些服务线程,并定期打印线程状态,运行结果如下:
  
  worker-0 start.
  [CalculateTask 0] start...
  worker-1 start.
  [TimerTask 0] start...
  [TimerTask 0] done.
  [CalculateTask 1] start...
  [CalculateTask 0] done.
  [TimerTask 1] start...
  [CalculateTask 1] done.
  [CalculateTask 2] start...
  [TimerTask 1] done.
  [TimerTask 2] start...
  [TimerTask 2] done.
  [CalculateTask 3] start...
  -----------------------------------------------
  Thread count = 2
  worker-0: busy
  worker-1: busy
  -----------------------------------------------
  [CalculateTask 2] done.
  [TimerTask 3] start...
  worker-2 start.
  [CalculateTask 4] start...
  worker-3 start.
  [TimerTask 4] start...
  worker-4 start.
  [CalculateTask 5] start...
  worker-5 start.
  [TimerTask 5] start...
  worker-6 start.
  [CalculateTask 6] start...
  [CalculateTask 3] done.
  [TimerTask 6] start...
  [TimerTask 3] done.
  [CalculateTask 7] start...
  [TimerTask 4] done.
  [TimerTask 7] start...
  [TimerTask 5] done.
  [CalculateTask 8] start...
  [CalculateTask 4] done.
  [TimerTask 8] start...
  [CalculateTask 5] done.
  [CalculateTask 9] start...
  [CalculateTask 6] done.
  [TimerTask 9] start...
  [TimerTask 6] done.
  [TimerTask 7] done.
  -----------------------------------------------
  Thread count = 7
  worker-0: idle
  worker-1: busy
  worker-2: busy
  worker-3: idle
  worker-4: busy
  worker-5: busy
  worker-6: busy
  -----------------------------------------------
  [CalculateTask 7] done.
  [CalculateTask 8] done.
  [TimerTask 8] done.
  [TimerTask 9] done.
  [CalculateTask 9] done.

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值