多线程线程池的实现java_如何在Java中实现线程池

多线程线程池的实现java

线程是独立程序的执行路径。 在java中,每个线程都扩展java.lang.Thread类或实现java.lang.Runnable。

多线程是指在一个任务中同时执行两个或多个线程。在多线程中,每个任务可以有多个线程,并且这些线程可以异步或同步地并行运行。 您可以在我在此处撰写的另一篇有关多线程的教程中找到有关线程和多线程的更多信息。

1.什么是线程池

线程池代表一组执行任务的工作线程,每个线程可以多次重用。 如果在所有线程都处于活动状态时提交了新任务,则它们将在队列中等待,直到某个线程可用为止。 线程池实现在内部使用LinkedBlockingQueue在队列中添加和删除任务。
我们通常想要的是一个工作队列,该队列与一组固定的工作线程组合在一起,该工作线程使用wait()notify()来向等待线程发出新工作到达的信号。 以下示例显示了一个简单的工作队列,该队列是Runnable对象的队列。 尽管没有特别要求Thread API使用Runnable接口,但这是调度程序和工作队列的通用约定。
package tutorials;import java.util.concurrent.LinkedBlockingQueue;public class ThreadPool {private final int nThreads;private final PoolWorker[] threads;private final LinkedBlockingQueue queue;public ThreadPool(int nThreads) {this.nThreads = nThreads;queue = new LinkedBlockingQueue();threads = new PoolWorker[nThreads];for (int i = 0; i < nThreads; i++) {threads[i] = new PoolWorker();threads[i].start();}}public void execute(Runnable task) {synchronized (queue) {queue.add(task);queue.notify();}}private class PoolWorker extends Thread {public void run() {Runnable task;while (true) {synchronized (queue) {while (queue.isEmpty()) {try {queue.wait();} catch (InterruptedException e) {System.out.println("An error occurred while queue is waiting: " + e.getMessage());}}task = queue.poll();}// If we don't catch RuntimeException,// the pool could leak threadstry {task.run();} catch (RuntimeException e) {System.out.println("Thread pool is interrupted due to an issue: " + e.getMessage());}}}}
}

在处理队列时使用同步块很重要,以控制线程对队列的访问。

package tutorials;public class Task implements Runnable {private int num;public Task(int n) {num = n;}public void run() {System.out.println("Task " + num + " is running.");}
}
import tutorials.Task;
import tutorials.ThreadPool;public class Main {public static void main(String[] args) {ThreadPool pool = new ThreadPool(7);for (int i = 0; i < 5; i++) {Task task = new Task(i);pool.execute(task);}
}

在上面的示例中,我们使用notify()而不是notifyAll() 。 因为notify()具有比notifyAll()更理想的性能特征; 特别是, notify()导致更少的上下文切换,这在服务器应用程序中很重要。 但是,使用时要确保重要notify()在其他情况下,因为与使用有关的微妙风险notify()它是唯一适当使用它在特定条件下。

下图演示了以上示例中的线程池设计。

图1。 线程池设计

2.有效使用线程池

线程池是一种用于构造多线程应用程序的强大机制,但并非没有风险。 使用线程池构建的应用程序可能具有与任何其他多线程应用程序相同的并发风险,例如死锁资源崩溃,同步或并发错误,线程泄漏和请求重载

这里有几点:

  • 不要将同步等待其他任务的任务排入队列,因为这会导致死锁。
  • 如果任务需要等待诸如I / O之类的资源,请指定最大等待时间,然后使任务执行失败或重新排队。 这保证了通过释放线程执行可能成功完成的另一任务将取得一些进展。
  • 有效地调整线程池的大小,并了解线程太少或线程太多都会导致问题。 线程池的最佳大小取决于可用处理器的数量以及工作队列上任务的性质。

3.结论

线程池对于组织服务器应用程序很有用,并且正确地实现它以防止任何问题(例如死锁和wait()notify()使用的复杂性)非常重要。 因此,建议考虑使用util.concurrent中的Executor类之一,例如ThreadPoolExecutor ,而不是从头开始编写线程池。 如果要求创建线程来处理短期任务,则可以考虑使用线程池。

4.下载源代码

这是线程池的教程,要下载源代码,请单击此处 。

翻译自: https://www.javacodegeeks.com/2016/12/implement-thread-pool-java.html

多线程线程池的实现java

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/335535.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

java timestamp是什么类型_JAVA比较2个Timestamp类型的时间大小-由此引发的思考

今天忽然要对2个Timestamp变量的类型进行比较。没怎么用过&#xff0c;百度发现居然很多都是转换类型的。后面发现Timestamp自己都有方法进行比较。但是百度一堆都是那些要转换类型的。我就想简单的知道2个Timestamp的时间哪个早哪个晚嘛。经过自己的百度的验证&#xff0c;终于…

Windows 使用命令执行 sql 脚本文件

文章目录MySQL 数据库方法一&#xff1a;使用 mysql 命令方法二&#xff1a;使用 source 命令Oracle 数据库MySQL 数据库 方法一&#xff1a;使用 mysql 命令 未配置 MySQL 的环境变量&#xff0c;则需要进入 MySQL 的 bin 目录下才能执行 mysql 命令已配置 MySQL 的环境变量…

windows系统连接同局域网下的其他电脑mysql等服务

一、首先设置被连接的mysql服务的 root 用户及访问权限&#xff08;必须确保连接用户拥有不限ip访问权限&#xff09; 参考&#xff1a;https://blog.csdn.net/hkl_Forever/article/details/127543546 二、配置被连接电脑的防火墙、网络共享、设置出入端口规则等 1、打开防火墙…

java中使用jython_将Jython嵌入到您的Java代码库中

java中使用jythonJython是一个使用相当可靠的语法的快速Java脚本的好工具。 实际上&#xff0c;当使用jmx为您的Java应用程序实现一些维护或监视脚本时&#xff0c;它的运行效果非常好。 如果您与其他具有python背景的团队合作&#xff0c;则将python集成到您的java应用程序是…

js如何获取jwt信息_谈房地产公众号如何涨粉?一篇文章让你轻松获取信息

原标题&#xff1a;谈房地产公众号如何涨粉&#xff1f;一篇文章让你轻松获取信息对于房地产企业来说&#xff0c;如何学会运营自己企业的房地产微信公众号是涨粉引流的关键一步&#xff0c;老话说&#xff1a;一步走好&#xff0c;步步稳。值得夸奖的是近几年中高端房地产企业…

java 统计数字个数_统计数字问题(Java)

Description一本书的页码从自然数1 开始顺序编码直到自然数n。书的页码按照通常的习惯编排&#xff0c;每个页码都不含多余的前导数字0。例如&#xff0c;第6 页用数字6 表示&#xff0c;而不是06 或006 等。数字计数问题要求对给定书的总页码n&#xff0c;计算出书的全部页码中…

Windows 命令终端(CMD)的快捷键

这些快捷键只在Windows系统操作有效&#xff0c;连接远程Linux主机&#xff0c;再操作这些快捷键是无效的&#xff0c;因为连接远程的Linux主机后&#xff0c;你用的是Linux命令终端。 快捷键&#xff1a; F1&#xff1a;按F1逐字显示最后一次执行的命令 F2&#xff1a;按F2会…

java开发plc上位机软件开发_上位机开发之西门子PLC-S7通信实践

写在前面&#xff1a;就目前而言&#xff0c;在中国的工控市场上&#xff0c;西门子仍然占了很大的份额&#xff0c;因此对于上位机开发而言&#xff0c;经常会存在需要与西门子PLC进行通信的情况。然后对于西门子PLC来说&#xff0c;通信方式有很多&#xff0c;下面简单列举一…

boss直聘账号异常登不上_【苹果IOS游戏账号分享】据说是最欢乐的2D冒险游戏?Q萌有趣,好不好玩你说了算——惊奇剑士...

惊奇剑士游戏下载点击下方卡片下载游戏&#xff01;不会使用请点击《操作指南》↓↓↓↓本游戏是由1群的资源库&#xff1a;“hentai是绅士不是变态” 赞助我们购买的&#xff0c;感谢大家的鼎力支持&#xff0c;二哈替大家感谢下hentai是绅士不是变态。可甜可盐的小哥哥之前还…

jquery 延迟加载代码_延迟加载是一种代码气味

jquery 延迟加载代码您见过那些具有许多属性的巨大物体吗&#xff1f; 这些域对象由于不希望从数据库检索太多信息而在其中使用延迟加载&#xff1f; 我敢打赌你有这种令人怀疑的快乐。 今天&#xff0c;我想与您分享我对它们的印象- 使用延迟加载应被视为一种代码味道&#x…

inotify-java下载_inotify-java-2.1.jar

【实例简介】inotify能够对文件系统进行监控&#xff0c;书上举的例子都是c使用inotify的例子&#xff0c;难道没有Java版吗&#xff0c;肯定有&#xff0c;只不过要自己编译&#xff0c;在网上找到别人的博客有&#xff0c;但是人家不愿意分享&#xff0c;我就只能自己编译了&…

SQL语句执行顺序

文章目录SQL 简介SQL 语句的执行顺序重点SQL 简介 SQL 是 Structured Query Language 的缩写&#xff0c;称为结构化查询语言&#xff0c;SQL 是一种操作关系型数据库的规则&#xff0c;SQL 语句以分号结尾&#xff0c;不区分大小写&#xff0c;建议关键词使用大写。 SQL 语句…

getexternalfilesdir 相册_音乐相册(电子相册制作)V5.2 安卓最新版

音乐相册(电子相册制作)是一个功能强大的电子相册创建工具。最新版本的音乐专辑应用程序可以帮助用户快速创建精美的多媒体专辑视频&#xff0c;并匹配优美的音乐伴奏&#xff0c;使照片更精彩。音乐专辑应用程序支持几乎所有流行的图片格式&#xff0c;并支持导入和导出&#…

jdk 9和jdk8_JDK 9是某些功能的终结

jdk 9和jdk8几天前宣布JDK 9是Feature Complete&#xff01; 进行切割的许多“功能”是附加功能&#xff0c;但有些是移除功能。 这篇文章介绍了一些从OpenJDK和/或Oracle JDK with Java 9中删除的项目。 JEP 220 &#xff08;“模块化运行时图像”&#xff09;的一部分是删除…

二级java题型及分值_2016年全国计算机二级java语言程序设计考试大纲

2016年全国计算机二级java语言程序设计考试大纲2016年3月计算机考试即将在3月26日-29日进行&#xff0c;为了帮助大家顺利通过2016年计算机二级考试&#xff0c;下面百分网小编为大家带来2016年全国计算机二级java语言程序设计考试大纲&#xff0c;供大家参考学习&#xff0c;预…

linux系统下安装jdk教程

一、首先下载linux版本jdk jdk官网&#xff1a;http://www.oracle.com/technetwork/java/javase/downloads/index.html 根据自己的需求&#xff0c;下载不同版本的jdk 2.将下载好的jdk压缩包&#xff0c;通过ftp上传到linux系统的当前用户下&#xff0c;我当前登录的用户为r…

mqtt java_MQTT和Java入门

mqtt javaMQTT&#xff08;MQ遥测传输&#xff09;是一种轻量级的发布/订阅消息传递协议。 MQTT在物联网应用程序中得到了广泛使用&#xff0c;因为它被设计为在占用空间小的系统上运行在远程位置。 MQTT 3.1是OASIS标准&#xff0c;您可以在http://mqtt.org/上找到所有信息。…

iphone11什么时候上市_hd3手表高仿哪里买 什么时候上市?

hd3手表高仿哪里买 什么时候上市? 导读&#xff1a;hd3手表高仿哪里买zf的万国7日链高仿表怎么样&#xff1f;款式设计非常出色&#xff0c;很多手表的款式&#xff0c;依靠着该性价比的迅速提升来做出的有效转化&#xff0c;年轻人对于复刻表的选择&#xff0c;能拥有的这些细…

arcgis工具python源码_面向Arcgis的python脚本编程_数据

【实例简介】《面向ArcGIS的Python脚本编程》是一本指导ArcGIS for Desktop专业用户进行Python开发的指南。该书将教会您如何通过编写Python代码处理空间数据并在ArcGIS中自动化实现地理处理任务【实例截图】【核心代码】面向arcgis的python脚本编程数据└── 面向arcgis的pyt…

Windows 命令终端(CMD)程序员常用的命令

文章目录certutilcddirmd/mkdirrddelreplacechdir/cdattribhelptypemorefindstrrename/renset环境变量扩展echonetstattskilltasklisttaskkillnettreecopystartpauseprintverwinversysteminfowmiclogofftracertroute printtelnetftppingipconfigshutdown远程关机formatchkdskti…