Java newFixedThreadPool线程池实例及讲解

闲话不多说,直接上代码。

<span style="font-size:18px;">import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;

public class MyThreadPool {

	private ExecutorService exe;
	private static final int POOL_SIZE = 4;

	public MyThreadPool() {
        exe = Executors.newFixedThreadPool(POOL_SIZE);
    }

	public void doTask() {
        int i = 0;
        while (i < 50) {
            exe.execute(new MyThread(i, exe));
            i++;
        }
    }

	class MyThread implements Runnable
    {
        int id;
        ExecutorService exe;
        MyThread(int id, ExecutorService exe) {
        	this.exe = exe;
            this.id = id;
        }
        public void run() {
        	System.out.println(id + "start");
        	try {
				Thread.sleep(5000L);
			} catch (InterruptedException e) {
				e.printStackTrace();
			}

        	System.out.println(id + "pass 5 second");
        	System.out.println("exe info:" + exe.toString());
        	try {
				Thread.sleep(5000L);
			} catch (InterruptedException e) {
				e.printStackTrace();
			}

            System.out.println(id + "end");
        }
    }

	public static void main(String[] args) {
        new MyThreadPool().doTask();
    }
}</span>

MyThreadPool为线程池管理类

MyThread为实际需要运行的线程类

运行log如下(一小部分):

<span style="font-size:18px;">1start
2start
3start
0start
2pass 5 second
exe info:[email protected][Running, pool size = 4, active threads = 4, queued tasks = 46, completed tasks = 0]
0pass 5 second
exe info:[email protected][Running, pool size = 4, active threads = 4, queued tasks = 46, completed tasks = 0]
3pass 5 second
exe info:[email protected][Running, pool size = 4, active threads = 4, queued tasks = 46, completed tasks = 0]
1pass 5 second
exe info:[email protected][Running, pool size = 4, active threads = 4, queued tasks = 46, completed tasks = 0]
2end
4start
0end
5start
3end
6start
1end
7start
</span>

可以看到当前在运行的线程只有前4个,队列中有46个任务在等待

只要有一个线程结束立即就会执行队列中的下一个线程

时间: 2024-11-10 08:29:41

Java newFixedThreadPool线程池实例及讲解的相关文章

java线程池实例

目的         了解线程池的知识后,写个线程池实例,熟悉多线程开发,建议看jdk线程池源码,跟大师比,才知道差距啊O(∩_∩)O 线程池类 1 package thread.pool2; 2 3 import java.util.LinkedList; 4 5 public class ThreadPool { 6 //最大线程数 7 private int maxCapacity; 8 //初始线程数 9 private int initCapacity; 10 //当前线程数 11 p

深入理解Java之线程池

原作者:海子 出处:http://www.cnblogs.com/dolphin0520/ 本文归作者海子和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利. 在前面的文章中,我们使用线程的时候就去创建一个线程,这样实现起来非常简便,但是就会有一个问题: 如果并发的线程数量很多,并且每个线程都是执行一个时间很短的任务就结束了,这样频繁创建线程就会大大降低系统的效率,因为频繁创建线程和销毁线程需要时间. 那么有没有一种办法使得线程可

[转]深入理解Java之线程池

出处:http://www.cnblogs.com/dolphin0520/ 本文归作者海子和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利. 在前面的文章中,我们使用线程的时候就去创建一个线程,这样实现起来非常简便,但是就会有一个问题: 如果并发的线程数量很多,并且每个线程都是执行一个时间很短的任务就结束了,这样频繁创建线程就会大大降低系统的效率,因为频繁创建线程和销毁线程需要时间. 那么有没有一种办法使得线程可以复用,就是执

Java(Android)线程池 总结

一种是使用Executors工厂生产线程池:另一种是直接使用ThreadPoolExecutor自定义. Executors工厂生产线程池 Java(Android)线程池 Trinea 介绍new Thread的弊端及Java四种线程池的使用,对Android同样适用.本文是基础篇,后面会分享下线程池一些高级功能. 1.new Thread的弊端执行一个异步任务你还只是如下new Thread吗? Java 1 2 3 4 5 6 7 newThread(newRunnable(){ @Ove

java自制线程池

个人博客:www.zalezone.cn java自制线程池 暂无评论 1. 简介 1.1. 线程池 1.2. 线程池作用 1.3. 线程池优点 1.4. JDK自带线程池 1.4.1. ThreadPoolExecutor 2. 自制线程池 2.1. 线程池主体类 2.2. 任务类 2.3. 测试类 简介 线程池 线程池的基本思想是一种对象池的思想,先开辟一块内存空间,开许多等待任务的线程,一旦有任务出现就直接使用线程池中的线程来进行任务,等到任务结束后再将这个线程放入线程池中,池中的执行调度

Java(Android)线程池---基础篇

1.new Thread的弊端 执行一个异步任务你还只是如下new Thread吗? 1 newThread(newRunnable(){ 2 3 @Override 4 publicvoidrun(){ 5 // TODO Auto-generated method stub 6 } 7 }).start(); 那你就out太多了,new Thread的弊端如下: a. 每次new Thread新建对象性能差.b. 线程缺乏统一管理,可能无限制新建线程,相互之间竞争,及可能占用过多系统资源导致

Java自定义线程池详解

自定义线程池的核心:ThreadPoolExecutor 为了更好的控制多线程,JDK提供了一套线程框架Executor,帮助开发人员有效的进行线程控制,其中在java.util.concurrent包下,是JDK并发包的核心,比如我们熟知的Executors.Executors扮演着线程工厂的角色,我们通过它可以创建特定功能的线程池,而这些线程池背后的就是:ThreadPoolExecutor.那么下面我们来具体分析下它. 构造ThreadPoolExecutor public ThreadP

关于Java中线程池的解读

之前的面试中多次被问到线程池的相关内容,所以在之后的时间内我仔细的学习了一下线程池的相关内容. 1.使用线程池的意义 复用:类似WEB服务器等系统,长期来看内部需要使用大量的线程处理请求,而单次请求响应时间通常比较短,此时Java基于操作系统的本地调用方式大量的创建和销毁线程本身会成为系统的一个性能瓶颈和资源浪费.若使用线程池技术可以实现工作线程的复用,即一个工作线程创建和销毁的生命周期期间内可以执行处理多个任务,从而总体上降低线程创建和销毁的频率和时间,提升了系统性能. 流控:服务器资源有限,

java中线程池

在jdk1.5中加入了java.util.concurrent,这个包中主要介绍java中线程以及线程池的使用 现在看怎么创建一个线程池,在java中Executors类创建线程池的,而线程池分为三类, 1:Executors.newFixedThreadPool(3);//这是固定的线程池 2: Executors.newCachedThreadPool();创建一个带缓存的线程池,比如创建了3个线程在线程池中,但是现在有10个线程在执行任务,因此它还会创建7个线程 3:Executors.n