线程池:
一、线程池:
用我的话来说,现在有很多线程任务要执行,比如很多人同时访问ITeye,这是,总不能来一个用户,就new一个线程去来接待用户吧,线程池就是预先创建了很多线程(用来处理任务线程的),当有任务需要执行时,就取出线程对象执行任务,执行完毕后,并不销毁(等待JVM回收)线程对象,而是将其放入一个集合中,等待下一次任务的执行
二、简单实现:
1.任务线程
package 线程池; /** * 运行的线程任务 * @author Administrator * */ public class RunThreadTask implements Runnable { String name; public void SetName(String name){ this.name =name; } public String getName(){ return name; } @Override public void run() { // TODO Auto-generated method stub String name1 = Thread.currentThread().getName(); try{ while(true){ System.out.println("当前运行的任务线程是:"+name+"<>"+"线程:"+name1); Thread.sleep(3000); } }catch(Exception ef){ System.out.println("异常中断"); } System.out.println("执行完毕"); } }
2.线程池:
package 线程池; import java.util.LinkedList; /** * 用线程池去管理 正在运行的线程任务 * @author Administrator * */ public class MyThreadPool { private int theCountOfThreadPool;//线程池的大小 private LinkedList theListOfRunThreadTask;//保存运行的线程任务的List private theThreadOfThreadPool[] theListOfThreadPool;//用来处理线程任务的List public void execute(RunThreadTask runTask){ synchronized (theListOfRunThreadTask) { theListOfRunThreadTask.addLast(runTask); theListOfRunThreadTask.notify(); System.out.println("加入了一个任务"+runTask.getName()); } } public static void main(String[] args) { MyThreadPool cb123456 = new MyThreadPool(10); RunThreadTask[] task = new RunThreadTask[20]; //theListOfRunThreadTask = LinkedList<RunThreadTask>; for (int i = 0; i < 20; i++) { task[i]= new RunThreadTask(); task[i].SetName("任务EE"+i); //task[i].getName(); //System.out.println("xxxx"+i); //task[i].run(); cb123456.execute(task[i]); } } public MyThreadPool(int count){ this.theCountOfThreadPool = count; theListOfRunThreadTask = new LinkedList(); //定义线程池的大小 theListOfThreadPool = new theThreadOfThreadPool[theCountOfThreadPool]; for (int i = 0; i < theListOfThreadPool.length; i++) { //初始化每一个线程 theListOfThreadPool[i] = new theThreadOfThreadPool(); theListOfThreadPool[i].setName(i+"号线程WWW"); theListOfThreadPool[i].start(); System.out.println(i+"号线程已经创建,等待任务"); } System.out.println("线程池初初始化完毕"); } public class theThreadOfThreadPool extends Thread{ @Override public void run() { // TODO Auto-generated method stub //super.run(); RunThreadTask r; while(true){ synchronized (theListOfRunThreadTask) { while(theListOfRunThreadTask.isEmpty()){ try{ theListOfRunThreadTask.wait(); }catch(InterruptedException ef){ } } //收到通知时,执行线程 r= (RunThreadTask) theListOfRunThreadTask.removeLast(); //此时r就是正在运行的线程任务; } //接着在让r对象run一下. r.run(); } } } }
三、运行结果:
四、执行流程:
通过构造函数,我们在线程池内创建了接待任务的线程,并让接待任务线程run起来,然后通过RunThreadTask[],创建任务线程对象,每次创建一个就让线程池去处理,再让任务线程run起来.大概就是这么个流程
五、结果分析:
按照湖南的话来说,就是每次显示都是一大坨,呵,就是每一毫秒,都会同时执行很多任务的.内存也不会飚到很高的。
六、补充:
Thread.currentThread():
七、总结:
使用线程池,不是很占我的内存,运行速度快,一次可以处理多个任务.
相关推荐
线程池线程池线程池线程池线程池线程池线程池线程池线程池线程池线程池线程池线程池线程池线程池线程池线程池线程池线程池线程池线程池线程池线程池线程池线程池线程池线程池线程池线程池线程池线程池线程池线程池...
corePoolSize:核心池的大小,在创建了线程池后,线程池中的线程数为0,当有任务来之后,就会创建一个线程去执行任务,当线程池中的线程数目达到corePoolSize后,就会把到达的任务放到缓存队列当中; ...
阻塞线程池阻塞线程池阻塞线程池阻塞线程池阻塞线程池阻塞线程池阻塞线程池阻塞线程池阻塞线程池阻塞线程池阻塞线程池阻塞线程池阻塞线程池阻塞线程池阻塞线程池阻塞线程池阻塞线程池阻塞线程池阻塞线程池阻塞线程池...
一、线程池 1、为什么需要使用线程池 1.1 创建/销毁线程伴随着系统开销,过于频繁的创建/销毁线程,会很大程度上影响处理效率。 记创建线程消耗时间T1,执行任务消耗时间T2,销毁线程消耗时间T3,如果T1+T3>T2,那...
VC实现线程池
易语言简易线程池的实现。 ——V雪落有声V原创。转载请保留。前文:。为了能充分理解本篇文章的内容,需要了解的知识如下:。1.事件对象的使用:http://baike.baidu.com/view/751499.htm。2.信号量的使用:...
简单的线程池程序+中文文档 包结构: com.tangkai.threadpool --SimpleThread.java 工作线程 --TestThreadPool.java 程序入口 --ThreadPoolManager.java 线程池管理类
Windows下一个比较完美的线程池实现和示例 本线程池提供了如下功能: 1.能根据任务个数和当前线程的多少在最小/最大线程个数之间自动调整(Vista后的系统有 SetThreadpoolThreadMaximum 等函数有类似功能); 2.能方便...
C#管理线程池的类 /* How to use Thread Classs * * ============== * public ELMService() { InitializeComponent(); etm.ClalThreadPool("EmailThreads", (uint)ApplicationInfo.EmailParsingThreads); ...
线程池
因为本人是个小白,多线程经常用,但是线程池并没有用过,(一听到线程池,总感觉高大上)。但是近期写彩票软件的时候发现,多线程长期操作会导致内容不断的升高直至报错,遂想起了线程池,完善后发现不是一般的叼...
2.然后根据提示运行java命令执行示例程序,观看线程池的运行结果 目标:Java中多线程技术是一个难点,但是也是一个核心技术。因为Java本身就是一个多线程语言。本人目前在给46班讲授Swing的网络编程--使用Swing来...
1.线程池管理器(ThreadPoolManager):用于创建并管理线程池 2.工作线程(WorkThread): 线程池中线程 3.任务接口(Task):每个任务必须实现的接口,以供工作线程调度任务的执行。 4.任务队列:用于存放没有处理的...
以下示例显示如何使用线程池。首先创建 ManualResetEvent 对象,此对象使程序能够知道线程池何时运行完所有的工作项。接着,尝试向线程池添加一个线程。如果添加成功,则添加其余的线程(本例中为 4 个)。然后...
linux线程池创建c实现 linux线程池创建c实现 linux线程池创建c实现 linux线程池创建c实现 linux线程池创建c实现 linux线程池创建c实现
使用Windows自带的线程池功能,比你写的线程池性能好得多
什么是线程池?简单点说,线程池就是有一堆已经创建好了的线程,初始它们都处于空闲等待状态,当有新的任务需要处理的时候,就从这个池子里面取一个空闲等待的线程来处理该任务,当处理完成了就再次把该线程放回池中...
这是一个简单线程池的实现,虽然有很多bug,但是能够简单地实现线程池。
Java开发,Android开发,自己实现线程池,明白线程池的实现机制
本实例采用c3p0作为线程池工具包,讲解了jdbc基本用法,同时给出了Oracle以及mysql增(单插入、批量插入)、删、查、改等功能,可以直接复制使用。