Java线程池newSingleThreadExecutor newFixedThreadPool newCachedThreadPool newScheduledThreadPool
Java线程池newSingleThreadExecutor newFixedThreadPool newCachedThreadPool newScheduledThreadPool
与数据库连接池类似的是,线程池在系统启动时即创建大量空闲的线程,程序将一个Runnable 对象或Callable 对象传给线程池,线程池就会启动一个线程来执行它们的run()或call()方法, 当run()或call()方法执行结束后, 该线程并不会死亡,而是再次返回线程池中成为空闲状态,等待执行下一个Runnable对象的run()或call()方法。
由于系统创建和销毁线程都是需要时间和系统资源开销,为了提高性能,才考虑使用线程池。线程池会在系统启动时就创建大量的空闲线程,然后等待新的线程调用,线程执行结束并不会销毁,而是重新进入线程池,等待再次被调用。这样子就可以减少系统创建启动和销毁线程的时间,提高系统的性能。
newSingleThreadExecutor:创建一个单线程的线程池。这个线程池只有一个线程在工作,也就是相当于单线程串行执行所有任务。如果这个唯一的线程因为异常结束,那么会有一个新的线程替代它。此线程池保证所有任务的执行顺序按照任务的提交顺序执行。
newFixedThreadPool:创建固定大小的线程池,每次提交一个任务就创建一个线程,直到线程达到线程池的最大大小。线程池的大小一旦达到是大值就会保持不变。如果某个线程因为执行异常而结束,那么线程池会补充一个新线程。
newCachedThreadPool:创建一个可缓存的线程池. 如果线程池的大小超过了处理任务所需要的线程,那么就会回收部分空闲(60秒不执行任务)的线程。当任务数增加时,此线程池又可以智能的添加新线程来处理任务。此线程池不会对钱程池大小做限制,线程池大小完全依赖于操作系统(或者说JVM) 能够创建的最大线程大小。
newScheduledThreadPool:创建一个大小无限的线程池。此线程池支持定时以及周期性执行任务的需求。
package javatest2;import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;public class javatest2 {public static void main(String[] args) {// 创建一个单线程的线程池// ExecutorService es = Executors.newSingleThreadExecutor();// 创建一个固定大小的线程池// ExecutorService es = Executors.newFixedThreadPool(2);// 创建一个可缓存的线程池//ExecutorService es = Executors.newCachedThreadPool();// 创建一个大小无限的线程池ExecutorService es = Executors.newScheduledThreadPool(2);MyThread my1 = new MyThread();// 线程1es.execute(my1);MyThread my2 = new MyThread();// 线程2es.execute(my2);}}class MyThread implements Runnable {@Overridepublic void run() {for (int i = 0; i < 5; i++) {try {Thread.sleep(500);} catch (InterruptedException e) {e.printStackTrace();}System.out.println("MyThread:" + i);}}
}
注意使用线程池时,Eclipse运行时,下图中会显示的红框点,因为线程池中的线程并没有因为空闲而被销毁,而普通线程执行完后就销毁了。
Java线程池newSingleThreadExecutor newFixedThreadPool newCachedThreadPool newScheduledThreadPool相关推荐
- java 线程池 简介
线程的实现方式 java 多线程之 extends Thread java 多线程之 implements Runnable java 多线程之 implements Callable 线程池的使用 ...
- Java自带的线程池Executors.newFixedThreadPool
线程池的基本思想还是一种对象池的思想,开辟一块内存空间,里面存放了众多(未死亡)的线程,池中线程执行调度由池管理器来处理.当有线程任务时,从池中取一个,执行完成后线程对象归池,这样可以避免反复创建线程 ...
- 四种Java线程池用法解析
四种Java线程池用法解析 本文为大家分析四种Java线程池用法,供大家参考,具体内容如下 http://www.jb51.net/article/81843.htm 1.new Thread的弊端 ...
- 面试必备:Java线程池解析
点击上方"方志朋",选择"设为星标" 做积极的人,而不是积极废人 来源:https://juejin.im/post/5d1882b1f265da1ba84aa ...
- Java 线程池详解学习:FixedThreadPool,CachedThreadPool,ScheduledThreadPool...
Java常用的线程池有FixedThreadPool和CachedThreadPool,我们可以通过查看他们的源码来进行学习. Java的源码下载参考这篇文章:Java源码下载和阅读(JDK1.8) ...
- Java线程池(一)
Java线程:新特征-线程池 线程池的基本思想还是一种对象池的思想,开辟一块内存空间,里面存放了众多(未死亡)的线程,池中线程执行调度由池管理器来处理.当有线程任务时,从池中取一个,执行完成后线程对象 ...
- Java线程池了解一下
前言 马上就要过年了,还在岗位上坚守"swimming"的小伙伴们顶住.博主给大家带来一篇线程池的基本使用解解闷. 为什么需要使用线程池 1.减少线程创建与切换的开销 在没有使用线 ...
- java 线程池原理分析
一.为什么使用线程池 1.降低资源消耗,减少线程创建和销毁次数,每个工作线程可以重复利用,执行多个任务 2.可根据系统承受能力,调整工作线程的数目,防止消耗过多的内存 二.java 线程池使用 Exe ...
- 面试题:四种Java线程池用法解析 !=!=未看
1.new Thread的弊端 执行一个异步任务你还只是如下new Thread吗? 1 2 3 4 5 6 7 8 new Thread(new Runnable() { @Override ...
最新文章
- GitHub开源的10个超棒后台管理面板
- 利用sharding-jdbc分库分表
- ionic1 打包过程 常用命令行
- 变成一列_Excel中将多列,快速变成1列,困惑了多年,今天总算学会了
- 跟我一起学Redis之高可用从主从复制开始
- 前端基础-html-标题标签
- [NOIP2011] 玛雅游戏
- connection error mysql_MySQL ConnectionError 安装错误 解决方法
- rancher中添加用户,赋予权限
- redis基础_NOSQL介绍
- Educoder关联规则挖掘
- Android Studio如何允许访问网络资源
- UNI-APP在iOS系统中加载来源于微信公众号的文章时(html片段),某些图片显示不出来的问题解决
- Shamir密钥分享算法简析
- Android开发之对上下两个图层的操作
- 通过阿里云api获取ecs主机信息
- OPPOA79K_OPPOA79KT_官方线刷包_救砖包_解账户锁
- python普通类实现接口_python3从零学习-5.8.1、socket—底层网络接口
- php 465端口发送邮件,云服务器使用SSL加密465端口发信样例及Demo
- Centos7 用户和组管理