`
zhangchengtian66
  • 浏览: 32072 次
  • 性别: Icon_minigender_1
最近访客 更多访客>>
社区版块
存档分类
最新评论

java线程池与工作队列

    博客分类:
  • java
阅读更多

java线程池与工作队列

http://www.newzz.cn/Program/JAVA/07244666264.html

 

 

import java.util.*;
public class WorkQueue
{
   private final int nThreads;//线程池的大小
   private final PoolWorker[] threads;//用数组实现线程池
   private final LinkedList queue;//任务队列

  public WorkQueue(int nThreads){
     this.nThreads = nThreads;
     queue = new LinkedList();
     threads = new PoolWorker[nThreads];

      for (int i=0; i         threads[i] = new PoolWorker();
         threads[i].start();//启动所有工作线程
      }
  }

  public void execute(Runnable r) {//执行任务
    synchronized(queue) {
            queue.addLast(r);
            queue.notify();
    }
  }

  private class PoolWorker extends Thread {//工作线程类
        public void run() {
               Runnable r;
               while (true) {
                    synchronized(queue) {
                      while (queue.isEmpty()) {//如果任务队列中没有任务,等待
                        try{
                          queue.wait();
                        }catch (InterruptedException ignored){}
                      }   
                       r = (Runnable) queue.removeFirst();//有任务时,取出任务
                   }
                   try {
                       r.run();//执行任务
                   }catch (RuntimeException e) {
                      // You might want to log something here
                  }
              }
      }
   }


 public static void main(String args[]){
      WorkQueue wq=new WorkQueue(10);//10个工作线程
      Mytask r[]=new Mytask[20];//20个任务
  
      for(int i=0;i<20;i++){
           r[i]=new Mytask();
           wq.execute(r[i]);
      }      
 }
}
class Mytask implements Runnable{//任务接口
         public void run(){
              String name=Thread.currentThread().getName();
              try{
                  Thread.sleep(100);//模拟任务执行的时间
              }catch(InterruptedException e){}
              System.out.println(name+" executed OK");
         }
  }
运行结果:

C:\java>java   WorkQueue
Thread-1 executed OK
Thread-2 executed OK
Thread-3 executed OK
Thread-4 executed OK
Thread-5 executed OK
Thread-6 executed OK
Thread-7 executed OK
Thread-8 executed OK
Thread-9 executed OK
Thread-10 executed OK
Thread-1 executed OK
Thread-2 executed OK
Thread-3 executed OK
Thread-4 executed OK
Thread-5 executed OK
Thread-6 executed OK
Thread-7 executed OK
Thread-8 executed OK
Thread-9 executed OK
Thread-10 executed OK   新站长

分享到:
评论
3 楼 guojian 2008-04-13  
Java 理论与实践: 线程池与工作队列

请详细的看一下这篇文章

http://www.ibm.com/developerworks/cn/java/j-jtp0730/index.html
2 楼 zhangchengtian66 2007-06-14  
是的,运行过的
1 楼 carlosbdw 2007-06-14  
这个程序你真的运行过吗?

相关推荐

    Java实现的线程池、消息队列功能

    标题中的“Java实现的线程池、消息队列功能”是指在Java编程中,如何利用编程技术实现线程池和消息队列这两种重要的并发处理机制。线程池和消息队列是解决多线程环境下资源管理和任务调度的有效手段,它们在高并发、...

    Java理论与实践:线程池与工作队列

    另一个常见的线程模型是为某一类型的任务分配一个后台线程与任务队列。AWT和Swing就使用这个模型,在这个模型中有一个GUI事件线程,导致用户界面发生变化的所有工作都必须在该线程中执行。然而,由于只有一个AWT线程...

    java 线程池实现多并发队列后进先出

    Java线程池是一种高效管理并发任务的机制,它允许开发者预先配置一定数量的线程,以便在处理多个并发任务时能有效地复用这些线程,从而避免了频繁创建和销毁线程带来的开销。在Java中,`java.util.concurrent`包下的...

    Android中的线程池与任务队列

    本文将深入探讨Android中线程池与任务队列的概念、工作原理以及它们如何协同工作。 线程池(ThreadPool)是一种多线程处理形式,处理过程中将任务添加到队列,然后在创建线程后自动启动这些任务。线程池可以避免因...

    并发-线程池和阻塞队列

    在Java编程中,"并发-线程池和...总之,理解和掌握线程池与阻塞队列的原理和使用方法,是提升Java并发编程能力的重要一步。它们为开发人员提供了一种强大而灵活的工具,能够在处理并发问题时保证系统的稳定性和性能。

    线程池&&队列各类区别使用场景

    总结来说,理解和掌握线程池与队列的区别和使用场景是优化并发程序的关键。线程池通过管理线程生命周期,减少了创建和销毁线程的开销,而队列则作为任务调度的媒介,保证了任务执行的顺序和线程间的同步。选择合适的...

    并发-线程池和阻塞队列.pdf

    对于有界队列,必须仔细考虑队列大小与线程池大小的配合,防止因线程池和队列不匹配造成的性能问题。 综上所述,线程池和阻塞队列是并发编程中的核心概念。它们的合理使用能够显著提升程序性能,降低资源消耗,并...

    java线程池封装j

    Java线程池的工作流程 1. 当有新任务提交时,如果当前线程池的线程数量小于核心线程数,会立即创建新线程执行任务。 2. 如果线程池达到核心线程数,新任务会被放入工作队列等待。 3. 当线程池中的线程数量大于核心...

    java线程池工作队列饱和策略代码示例

    Java线程池工作队列饱和策略代码示例 Java线程池工作队列饱和策略是Java并发编程中的一种重要机制,用于处理线程池中工作队列的饱和问题。在本文中,我们将详细介绍Java线程池工作队列饱和策略的概念、原理和实现。...

    Java 线程池的原理与实现

    Java线程池是一种高级的多线程处理框架,它是Java并发编程中非常重要的一个组件。线程池的原理和实现涉及到操作系统调度、内存管理和并发控制等多个方面。理解线程池的工作原理有助于优化程序性能,避免过度创建和...

    Java线程池与ThreadPoolExecutor.pdf

    Java线程池是Java并发编程中的重要组成部分,它允许开发者管理多个线程并有效地调度任务。线程池通过ThreadPoolExecutor类实现,这是一个高度可配置的工具,能够根据具体需求定制线程的创建、管理和销毁策略。 ...

    java线程池实例详细讲解

    Java线程池是一种高效管理线程资源的工具,它能够帮助开发者有效地控制并调度线程,从而提升系统性能,减少系统资源的浪费。在Java中,`ExecutorService`接口是线程池的主要入口,它是`java.util.concurrent`包的一...

    Java线程池使用说明

    Java线程池是Java并发编程中的重要组件,它能够有效地管理和复用线程,从而提高程序的执行效率和降低资源消耗。在JDK 1.5版本之前,Java对线程池的支持非常有限,而在JDK 1.5之后,加入了java.util.concurrent包,...

    Java线程池文档

    Java线程池是一种高效管理线程的机制,它允许开发者预先设定线程的数量,并通过池化的方式重用已创建的线程,以提高系统性能,减少线程的创建和销毁开销。线程池在Java中是通过`java.util.concurrent`包下的`...

    自定义实现Java线程池

    ### 自定义实现Java线程池 #### 一、概述 在深入探讨自定义Java线程池之前,我们先简要回顾一下线程池的基本概念及其重要性。线程池是一种多线程处理形式,处理过程中将任务添加到队列,然后在创建线程后自动启动...

    JAVA线程池的原理与实现.pdf

    Java线程池是一种高效利用系统资源、管理并发执行任务的机制。...总的来说,理解Java线程池的工作原理和实现对于优化并发应用程序至关重要,它可以帮助我们更好地控制系统的并发度,提高系统的响应速度和资源利用率。

    JAVA线程池例子

    Java线程池是一种高效管理线程资源的技术,它允许开发者创建一组可重用的工作线程,从而避免频繁地创建和销毁线程带来的性能开销。线程池在Java中主要通过`java.util.concurrent`包中的`ExecutorService`接口及其...

Global site tag (gtag.js) - Google Analytics