`

JDK1.5 线程池

阅读更多

 



 

Executors类主要方法:

a.       static ExecutorService newCachedThreadPool()

产生一个ExecutorService对象,这个对象带有一个线程池,线程池的大小会根据需要调整,线程执行完任务后返回线程池,供执行下一次任务使用

b.       static ExecutorService newFixedThreadPool(int poolSize)

产生一个ExecutorService对象,这个对象带有一个大小为poolSize的线程池,若任务数量大于poolSize,任务会被放在一个queue里顺序执行

c.       static ExecutorService newSingleThreadExecutor()

产生一个ExecutorService对象,这个对象只有一个线程可用来执行任务,若任务多于一个,任务将按先后顺序执行。

 

一.static ExecutorService newFixedThreadPool(int poolSize)创建一个可重用固定线程集合的线程池,以共享的无界队列方式来运行这些线程。

实例1

package com.bijian.thread;

public class MyThread extends Thread {
	
	private String nickName;
	
	public MyThread(String nickName) {
		super();
		this.nickName = nickName;
	}

	@Override
	public void run() {

		try {
			Thread.sleep(50);
		} catch(Exception e) {
			
		}

		System.out.println(Thread.currentThread().getName() + ": "+ nickName + "正在执行。。。");
		
		try {
			Thread.sleep(100);
		} catch(Exception e) {
			
		}
	}
}

 

package com.bijian.thread;

import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;

public class Main {

	/**
	 * @param args
	 */
	public static void main(String[] args) {
		//创建一个可重用固定线程数的线程池
		ExecutorService pool = Executors.newFixedThreadPool(2);
		//创建实现了Runnable 接口对象,Thread 对象当然也实现了Runnable 接口
		Thread t1 = new MyThread("A");
		Thread t2 = new MyThread("B");
		Thread t3 = new MyThread("C");
		Thread t4 = new MyThread("D");
		Thread t5 = new MyThread("E");
		//将线程放入池中进行执行
		pool.execute(t1);
		pool.execute(t2);
		pool.execute(t3);
		pool.execute(t4);
		pool.execute(t5);
		//pool.exe
		
		//关闭线程池
		pool.shutdown();
	}
}

 

运行结果:
pool-1-thread-2: B正在执行。。。
pool-1-thread-1: A正在执行。。。
pool-1-thread-2: C正在执行。。。
pool-1-thread-1: D正在执行。。。
pool-1-thread-1: E正在执行。。。

 

 

二.static ExecutorServicenewSingleThreadExecutor()创建一个使用单个 worker 线程的 Executor,以无界队列方式来运行该线程。

实例2(修改Main类如下):

package com.bijian.thread;

import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;

public class Main {

	/**
	 * @param args
	 */
	public static void main(String[] args) {
		//创建一个使用单个 worker 线程的 Executor,以无界队列方式来运行该线程
		ExecutorService pool = Executors.newSingleThreadExecutor();
		//创建实现了Runnable 接口对象,Thread 对象当然也实现了Runnable 接口
		Thread t1 = new MyThread("A");
		Thread t2 = new MyThread("B");
		Thread t3 = new MyThread("C");
		Thread t4 = new MyThread("D");
		Thread t5 = new MyThread("E");
		//将线程放入池中进行执行
		pool.execute(t1);
		pool.execute(t2);
		pool.execute(t3);
		pool.execute(t4);
		pool.execute(t5);
		//关闭线程池
		pool.shutdown();
	}
}

 

运行结果:
pool-1-thread-1: A正在执行。。。
pool-1-thread-1: B正在执行。。。
pool-1-thread-1: C正在执行。。。
pool-1-thread-1: D正在执行。。。
pool-1-thread-1: E正在执行。。。

 

 

三.static ExecutorServicenewCachedThreadPool()创建一个可根据需要创建新线程的线程池,但是在以前构造的线程可用时将重用它们。

实例3修改Main类如下): 

package com.bijian.thread;

import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;

public class Main {

	/**
	 * @param args
	 */
	public static void main(String[] args) {
		//创建一个可根据需要创建新线程的线程池,但是在以前构造的线程可用时将重用它们
		ExecutorService pool = Executors.newCachedThreadPool();
		//创建实现了Runnable 接口对象,Thread 对象当然也实现了Runnable 接口
		Thread t1 = new MyThread("A");
		Thread t2 = new MyThread("B");
		Thread t3 = new MyThread("C");
		Thread t4 = new MyThread("D");
		Thread t5 = new MyThread("E");
		//将线程放入池中进行执行
		pool.execute(t1);
		pool.execute(t2);
		pool.execute(t3);
		pool.execute(t4);
		pool.execute(t5);
		
		try {
			Thread.sleep(4000);
		} catch(Exception e) {
			
		}
		
		Thread t6 = new MyThread("F");
		pool.execute(t6);
		
		//关闭线程池
		pool.shutdown();
	}
}

 运行结果: 

pool-1-thread-1: A正在执行。。。
pool-1-thread-5: E正在执行。。。
pool-1-thread-4: D正在执行。。。
pool-1-thread-2: B正在执行。。。
pool-1-thread-3: C正在执行。。。
pool-1-thread-1: F正在执行。。。

 

 四.static ScheduledExecutorServicenewScheduledThreadPool(int corePoolSize): 创建一个线程池,它可安排在给定延迟后运行命令或者定期地执行。

       ScheduledExecutorService接口方法:

        ScheduledFuture<?> schedule(Runnable command, long delay, TimeUnit unit)创建并执行在给定延迟后启用的一次性操作。

实例4修改Main类如下): 

package com.bijian.thread;

import java.util.concurrent.Executors;
import java.util.concurrent.ScheduledExecutorService;
import java.util.concurrent.TimeUnit;

public class Main {

	/**
	 * @param args
	 */
	public static void main(String[] args) {
		//创建一个线程池,它可安排在给定延迟后运行命令或者定期地执行
		ScheduledExecutorService pool = Executors.newScheduledThreadPool(2);
		//创建实现了Runnable 接口对象,Thread 对象当然也实现了Runnable 接口
		Thread t1 = new MyThread("A");
		Thread t2 = new MyThread("B");
		Thread t3 = new MyThread("C");
		Thread t4 = new MyThread("D");
		Thread t5 = new MyThread("E");
		//将线程放入池中进行执行
		pool.execute(t1);
		pool.execute(t2);
		pool.execute(t3);
		
		//1000毫秒后执行t4线程
		pool.schedule(t4, 1000, TimeUnit.MILLISECONDS);
		//1000毫秒后执行t5线程
		pool.schedule(t5, 1000, TimeUnit.MILLISECONDS);
		//关闭线程池
		pool.shutdown();
	}
}

 运行结果: 

pool-1-thread-2: B正在执行。。。
pool-1-thread-1: A正在执行。。。
pool-1-thread-1: C正在执行。。。
pool-1-thread-2: D正在执行。。。
pool-1-thread-1: E正在执行。。。

 

 

五.static ScheduledExecutorServicenewSingleThreadScheduledExecutor()创建一个单线程执行程序,它可安排在给定延迟后运行命令或者定期地执行。

实例5修改Main类如下): 

package com.bijian.thread;

import java.util.concurrent.Executors;
import java.util.concurrent.ScheduledExecutorService;
import java.util.concurrent.TimeUnit;

public class Main {

	/**
	 * @param args
	 */
	public static void main(String[] args) {
		//创建一个单线程执行程序,它可安排在给定延迟后运行命令或者定期地执行
		ScheduledExecutorService pool = Executors.newSingleThreadScheduledExecutor();
		//创建实现了Runnable 接口对象,Thread 对象当然也实现了Runnable 接口
		Thread t1 = new MyThread("A");
		Thread t2 = new MyThread("B");
		Thread t3 = new MyThread("C");
		Thread t4 = new MyThread("D");
		Thread t5 = new MyThread("E");
		//将线程放入池中进行执行
		pool.execute(t1);
		pool.execute(t2);
		pool.execute(t3);
		
		pool.schedule(t4, 5000, TimeUnit.MILLISECONDS);
		pool.schedule(t5, 1000, TimeUnit.MILLISECONDS);
		//关闭线程池
		pool.shutdown();
	}
}

 运行结果: 

pool-1-thread-1: A正在执行。。。
pool-1-thread-1: B正在执行。。。
pool-1-thread-1: C正在执行。。。
pool-1-thread-1: E正在执行。。。
pool-1-thread-1: D正在执行。。。

  

.ThreadPoolExecutor(int corePoolSize, int maximumPoolSize, long keepAliveTime, TimeUnit unit, BlockingQueue<Runnable> workQueue) :用给定的初始参数和默认的线程工厂及处理程序创建新的 ThreadPoolExecutor

实例6修改Main类如下): 

package com.bijian.thread;

import java.util.concurrent.ArrayBlockingQueue;
import java.util.concurrent.BlockingQueue;
import java.util.concurrent.ThreadPoolExecutor;
import java.util.concurrent.TimeUnit;

public class Main {

	/**
	 * @param args
	 */
	public static void main(String[] args) {
		//创建等待队列
		BlockingQueue<Runnable> bqueue = new ArrayBlockingQueue<Runnable>(20);
		//用给定的初始参数和默认的线程工厂及处理程序创建新的 ThreadPoolExecutor
		ThreadPoolExecutor pool = new ThreadPoolExecutor(2,3,2,TimeUnit.MILLISECONDS,bqueue);
		//创建实现了Runnable 接口对象,Thread 对象当然也实现了Runnable 接口
		Thread t1 = new MyThread("A");
		Thread t2 = new MyThread("B");
		Thread t3 = new MyThread("C");
		Thread t4 = new MyThread("D");
		Thread t5 = new MyThread("E");
		Thread t6 = new MyThread("F");
		Thread t7 = new MyThread("G");
		
		bqueue.add(t7);
		bqueue.add(t2);
		bqueue.add(t3);
		bqueue.add(t1);
		bqueue.add(t5);
		bqueue.add(t6);
		bqueue.add(t4);
		bqueue.add(t1);
		
		//关闭线程池
		pool.shutdown();
	}
}

 运行结果(线程池依次执行队列中的线程对象): 

pool-1-thread-1: G正在执行。。。
pool-1-thread-1: B正在执行。。。
pool-1-thread-1: C正在执行。。。
pool-1-thread-1: A正在执行。。。
pool-1-thread-1: E正在执行。。。
pool-1-thread-1: F正在执行。。。
pool-1-thread-1: D正在执行。。。
pool-1-thread-1: A正在执行。。。

 

JDK1.5自带线程池的好处:

a.       分配线程、线程使用完回收至线程池、线程池没有线程可分配等待这些工作都是自动完成的

b.       方法的操作非常简便

  • 大小: 68.7 KB
分享到:
评论

相关推荐

    神奇宝贝(PokemonGo)基于Jetpack+MVVM+Repository设计模式+Data.zip

    神奇宝贝(PokemonGo)基于Jetpack+MVVM+Repository设计模式+Data

    用于试用 Dev Containers 的 Python 示例项目.zip

    用于试用 Dev Containers 的 Python 示例项目试用开发容器Python开发容器是一个具有明确定义的工具/运行时堆栈及其先决条件的运行容器。您可以使用GitHub Codespaces或Visual Studio Code Dev Containers试用开发容器。这是一个示例项目,您可以通过几个简单的步骤尝试任一选项。我们还有各种其他vscode-remote-try-*示例项目。注意如果您已经有代码空间或开发容器,则可以跳至“要尝试的事情”部分。设置开发容器GitHub Codespaces请按照以下步骤在 Codespace 中打开此示例单击代码下拉菜单。单击Codespaces选项卡。单击主屏幕上的“创建代码空间”。有关创建代码空间的更多信息,请访问GitHub 文档。VS Code 开发容器如果您已安装 VS Code 和 Docker,则可以单击上方或此处的徽章开始使用。单击这些链接将导致 VS Code 根据需要自动安装 Dev Containers 扩展,将源代码克隆到容器卷中,并启动开发容器以供使用。按

    springboot vue3前后端分离.zip

    springboot vue3前后端分离

    数学建模-神经网络算法 lecture 11 线性随机系统辨识示例 共9页.pptx

    数学建模-神经网络算法 lecture 11 线性随机系统辨识示例 共9页.pptx

    优质粳稻生产技术规程.docx

    优质粳稻生产技术规程.docx

    所有算法均在 Python 3 中实现,是 hacktoberfest2020 的一个项目 - 没有针对 hacktoberfest 2021 的问题或 PR.zip

    算法 - Python 目录灵感与动力贡献指南从这里开始所有算法均用 Python 3 实现(用于教育)这些实现仅用于学习目的。如果您想贡献更有效的解决方案,请随时打开问题并提交您的解决方案。灵感你可以在LeetCode 算法中寻找要实现的算法若要贡献,请确保算法尚未提交!请确保在您的 PR 中添加问题编号。贡献指南文件夹和文件请确保你的文件位于 -Folder 中LeetCode,并且命名如下 0001_TwoSum.py-> LeetCode 问题的 4 位数字、下划线、LeetCodeName开放问题当您打开问题时,请确保问题尚未实现(查看代码/Leetcode 以获取问题编号)。现有问题打开的问题将被关闭,并且对此问题的 PR 被标记为垃圾邮件 。打开问题的贡献者将被优先分配到该问题。如果大约 7 天内没有 PR,则问题将分配给另一个贡献者。拉取请求只有与问题相结合并符合命名约定(参见文件夹和文件)的 Pull 请求才会被合并!如果 PR 中没有加入问题,您的 PR 将被标记为垃圾邮件并关闭。如果您的代码未通

    用于接收和交互来自 Slack 的 RTM API 的事件的框架.zip

    用于接收和交互来自 Slack 的 RTM API 的事件的框架python-rtmbot此项目不再处于积极开发阶段。如果您刚刚开始,我们建议您先查看Python SDK。如果您一直在使用此项目,我们只会解决关键问题(例如安全问题),但我们建议您计划迁移到 Python SDK。您仍然可以提交问题并向我们寻求帮助! 如果您有兴趣在未来维护此软件包,请联系我们 一个用 Python 编写的 Slack 机器人,通过 RTM API 连接。Python-rtmbot 是一个机器人引擎。任何了解Slack API和 Python的人都应该熟悉插件架构。配置文件格式为 YAML。该项目目前处于 1.0 之前的版本。因此,您应该计划不时进行重大更改。对于任何重大更改,我们将在 1.0 之前的版本中调整次要版本。(例如 0.2.4 -> 0.3.0 意味着重大更改)。如果稳定性很重要,您可能希望锁定特定的次要版本)与 webhook 的一些区别不需要网络服务器来接收消息可以回复用户的直接消息以 Slack 用户(或机器人)身份登录机器人用户必须被邀请加入频道

    基于django的音乐推荐系统.zip

    基于django的音乐推荐系统.zip

    北京理工大学<Python机器学习应用>超详细学习笔记和代码注释(未完待续).zip

    北京理工大学<Python机器学习应用>超详细学习笔记和代码注释(未完待续)

    kernel-5.15-rc7.zip

    kernel-5.15-rc7.zip

    神经网络-DenseNet网络结构

    神经网络-DenseNet网络结构

    rbac组件(基于角色的权限控制).zip

    rbac组件(基于角色的权限控制)

    C++ Vigenère 密码(解密代码)

    C++ Vigenère 密码(解密代码)

    数学建模培训资料 数学建模实战题目真题答案解析解题过程&论文报告 杭州消防设置-对杭州市消防局设置的研究 共8页.pdf

    数学建模培训资料 数学建模实战题目真题答案解析解题过程&论文报告 杭州消防设置-对杭州市消防局设置的研究 共8页.pdf

    老年用品产品推广目录分类表.docx

    老年用品产品推广目录分类表.docx

    毕设源码-基于Python的期货程序化交易系统的设计与实现_jhypi-期末大作业+说明文档.rar

    本项目是基于Python的期货程序化交易系统的设计与实现,旨在为计算机相关专业学生提供一个实践性强、贴近实际应用场景的项目案例。通过这一项目,学生们能够深入了解程序化交易的基本原理和实现方法,同时锻炼自身的编程技能、数据分析能力以及金融市场的洞察力。 项目的主要功能包括:自动收集和处理市场数据、基于预设策略进行交易决策、实时执行交易指令、监控交易风险以及生成详细的交易报告。系统采用模块化设计,主要包括数据采集模块、策略执行模块、交易执行模块和风险管理模块,各个模块之间通过明确的接口进行交互。项目采用的编程语言为Python,利用其强大的数据处理库和机器学习库,保证了系统的灵活性和扩展性。开发这一项目的目的是让学生们在实践中学习和掌握程序化交易的核心技术,提升其在金融科技领域的就业竞争力。

    基于java的校园失物招领平台设计与实现.docx

    基于java的校园失物招领平台设计与实现.docx

    Javascript Ninja 课程.zip

    Javascript Ninja 课程JavaScript Ninja 课程Inscreva-se agora mesmo e ganhe 10% de desconto!Como tirar dúvidas sobre 或 conteúdo do curso访问问题页面Pesquise nas发出abertas e fechadas, se a mesma dúvida já foi postadaSe não foi, crie uma nova issues , coloque um titulo que tenha a ver com a sua dúvida, e descreva-a com o maior nível detalhes possíveis, para que possamos te ajudar:)摘要Veja o sumário completo do curso aqui。赞同!:D

    通过示例在 Python 中解释 SOLID 原则 .zip

    solid.python通过示例在 Python 中解释SOLID 原则。单一职责原则开放/封闭原则里氏替换原则接口隔离原则依赖倒置原则

    公交信息在线查询系统 微信小程序+SSM毕业设计 源码+数据库+论文+启动教程.zip

    公交信息在线查询系统 微信小程序+SSM毕业设计 源码+数据库+论文+启动教程 项目启动教程:https://www.bilibili.com/video/BV1BfB2YYEnS

Global site tag (gtag.js) - Google Analytics