ExecutorService线程池简单使用
简介
ExecutorService是Java中对线程池定义的一个接口,它位于java.util.concurrent包中,在这个接口中定义了和后台任务执行相关的方法。
常用方法
public <T> Future<T> submit(Callable<T> task): 执行一个任务,并获取执行结果。
public void execute(Runnable command): 执行一个任务,无返回结果。
代码
/**
* 第一个参数corePoolSoze核心线程数,最开始的时候是有这个线程池里面是有一定的核心线程数的;
* 核心线程数紫瑶不手动调用方法关闭,就一直存在;
*
* 第二个maximumPoolSize最大线程数,线程数不够了,能扩展到最大线程是多少;
*
* 第三个keepAliveTime生存时间,意思是这个线程有很长时间没干活了请你把它归还给操作系统(非核心线程);
*
* 第四个TimeUnit.SECONDS生存时间的单位到底是毫秒纳秒还是秒自己去定义;
*
* 第五个是任务队列,就是我们上节课讲的BlockingQueue,各种各样的BlockingQueue你都可以往里面扔,
* 我们这用的是ArrayBlockingQueue,先进先出,最多装入10个任务;
*
* 第六个是线程工厂defaultThreadFactory,他返回的是一个enw DefaultThreadFactory,它要去你去实现ThreadFactory的接口,
* 这个接口只有一个方法叫newThread,所以就是产生线程的,可以通过这种方式产生自定义的线程,默认产生的是defaultThreadFactory,
* 而defaultThreadFactory产生线程的时候有几个特点:new出来的时候指定了group制定了线程名字,然后指定的这个线程绝对不是守护线程,
* 设定好你线程的优先级。自己可以定义产生的到底是什么样的线程,指定线程名叫什么(为什么要指定线程名称,有什么意义,就是可以方便出错是回溯);
*
* 第七个叫拒绝策略,指的是线程池忙,而且任务队列满这种情况下我们就要执行各种各样的拒绝策略,jdk默认提供了四种拒绝策略,也是可以自定义的。自定义拒绝策略需要实现RejectedExecutionHandler接口
*
* 1: Abort:抛异常
*
* 2:Discard:扔掉,不抛异常
*
* 3:DiscardOldest:扔掉排队时间最久的
*
* 4:CallerRuns:调用者处理服务,一般是主线程。
**/
ThreadPoolExecutor executor=new ThreadPoolExecutor(2,3,1000, TimeUnit.SECONDS,new ArrayBlockingQueue(10), Executors.defaultThreadFactory(),
new ThreadPoolExecutor.CallerRunsPolicy());
ExecutorServiceDemo serviceDemo=new ExecutorServiceDemo();
//submit() 该方法可以获取返回值 异步
Future<String> submit = executor.submit(serviceDemo::taskOne);
try {
//获取返回结果,阻塞
String result = submit.get();
System.out.println("获取线程返回结果: "+result);
} catch (InterruptedException e) {
e.printStackTrace();
} catch (ExecutionException e) {
e.printStackTrace();
}
executor.execute(serviceDemo::taskOne);
}
JDK提供的线程池
SingleThreadExecutor(单个工作线程的线程池)
简介
线程池里面只有一个线程,这一个线程也是核心线程,这个一个线程的线程池可以保证我们扔进去的任务是顺序执行的。
代码
public void singleThreadExecutorDemo(){
ExecutorService service = Executors.newSingleThreadExecutor();
for(int i=0; i<5; i++) {
final int j = i;
service.execute(()->{
try {
//睡眠,占用当前线程
TimeUnit.MILLISECONDS.sleep(500);
} catch (InterruptedException e) {
e.printStackTrace();
}
System.out.println("单个工作线程的线程池的线程名: " + Thread.currentThread().getName());
});
}
}
CachedThreadPool(缓存线程池)
简介
没有核心线程,最大线程数为Integer.MAX_VALUE,产生的线程若60秒没有执行任务,将回收,他的任务队列用的是SynchronousQueue(即无队列),使用默认工厂产生线程,线程数达到最大值时采取Abort,即抛出异常。
代码
public void cachedThreadPoolDemo(){
ExecutorService service = Executors.newCachedThreadPool();
System.out.println("开始: "+service);
for (int i = 0; i < 18; i++) {
service.execute(() -> {
try {
TimeUnit.MILLISECONDS.sleep(500);
} catch (InterruptedException e) {
e.printStackTrace();
}
System.out.println("缓存线程池的线程名: "+Thread.currentThread().getName());
});
}
try {
TimeUnit.MILLISECONDS.sleep(1000);
} catch (InterruptedException e) {
e.printStackTrace();
}
//输出线程的相关信息
System.out.println("结束: "+service);
}
FixedThreadPool(固定线程数的线程池)
简介
线程全是核心线程,没有非核心线程。
代码
public void fixedThreadPoolDemo(){
//服务器核心数
final int cpuCoreNum = 4;
ExecutorService service = Executors.newFixedThreadPool(cpuCoreNum);
for (int i = 0; i < 8; i++) {
service.execute(() -> {
try {
TimeUnit.MILLISECONDS.sleep(500);
} catch (InterruptedException e) {
e.printStackTrace();
}
System.out.println("固定线程数的线程池的线程名: "+Thread.currentThread().getName());
});
}
}
ScheduledThreadPool(定时任务线程池)
简介
根据自定义参数进行周期性执行任务,自定义核心线程数,线程最大值无上线,队列使用的是延时队列。
代码
public void scheduledPoolDemo() {
ScheduledExecutorService service = Executors.newScheduledThreadPool(3);
//第一个参数(Delay)第一个任务执行之前需要往后面推多长时间;
// 第二个(period)间隔多长时间;第三个参数是时间单位;
System.out.println("开始执行任务,时间为: " + System.currentTimeMillis());
service.scheduleAtFixedRate(() -> {
System.out.println("线程名为: " + Thread.currentThread().getName());
System.out.println("定时执行任务时间: " + System.currentTimeMillis());
}, 3, 5, TimeUnit.SECONDS);
}
Gitee地址
ExecutorService线程池简单使用的更多相关文章
- Android线程管理之ExecutorService线程池
前言: 上篇学习了线程Thread的使用,今天来学习一下线程池ExecutorService. 线程管理相关文章地址: Android线程管理之Thread使用总结 Android线程管理之Execu ...
- Android学习笔记之ExecutorService线程池的应用....
PS:转眼间就开学了...都不知道这个假期到底是怎么过去的.... 学习内容: ExecutorService线程池的应用... 1.如何创建线程池... 2.调用线程池的方法,获取线程执行完毕后的结 ...
- java android ExecutorService 线程池解析
ExecutorService: 它也是一个接口,它扩展自Executor接口,Executor接口更像一个抽象的命令模式,仅有一个方法:execute(runnable);Executor接口简单, ...
- ExecutorService线程池
ExecutorService 建立多线程的步骤: 1.定义线程类 class Handler implements Runnable{} 2.建立ExecutorService线程池 Executo ...
- Handler+ExecutorService(线程池)+MessageQueue模式+缓存模式
android线程池的理解,晚上在家无事 预习了一下android异步加载的例子,也学习到了一个很重要的东东 那就是线程池+缓存 下面看他们的理解.[size=1.8em]Handler+Runna ...
- ExecutorService线程池讲解
ExecutorService 建立多线程的步骤: 1.定义线程类 class Handler implements Runnable{ } 2.建立ExecutorService线程池 Execut ...
- 【转】Handler+ExecutorService(线程池)+MessageQueue模式+缓存模式
http://www.cnblogs.com/wanqieddy/archive/2013/09/06/3305482.html android线程池的理解,晚上在家无事 预习了一下android异步 ...
- 【转】[Android实例] Handler+ExecutorService(线程池)+MessageQueue模式+缓存模式
android线程池的理解,晚上在家无事 预习了一下android异步加载的例子,也学习到了一个很重要的东东 那就是线程池+缓存 下面看他们的理解. [size=1.8em]Handler+Runn ...
- [Android实例] Handler+ExecutorService(线程池)+MessageQueue模式+缓存模式
android线程池的理解,晚上在家无事 预习了一下android异步加载的例子,也学习到了一个很重要的东东 那就是线程池+缓存 下面看他们的理解. [size=1.8em]Handler+Runn ...
随机推荐
- [Xavier] Understanding the difficulty of training deep feedforward neural networks
目录 概 主要内容 Glorot X, Bengio Y. Understanding the difficulty of training deep feedforward neural netwo ...
- uniapp中拿到base64转blob对象,或base64转bytes字节数组,io操作写入字节流文件bytes
1. uniAPP中拿到附件的base64如何操作,如word文件 /*** 实现思路:* 通过native.js的io操作创建文件,拿到平台绝对路径* 再通过原生类进行base64解码,拿到字节流b ...
- Linux开关机与登录注销
开机和重启 shutdown -h now:立即关机计算机 shutdown -h 1:1分钟后关机 halt:立即关机 reboot:立即重启 sync:把内存的数据同步到磁盘 注: shutdow ...
- Java HotSpot(TM) 64-Bit Server VM warning: ignoring option MaxPermSize=256M; support was removed in 8.0
目录 启动一个Java Standalone程序时报错 解决办法 解释 参考 启动一个Java Standalone程序时报错 Java HotSpot(TM) 64-Bit Server VM wa ...
- 第10组-Alpha冲刺 总结
1.基本情况 组长博客链接:https://www.cnblogs.com/cpandbb/p/14007413.html 答辩总结: ·产品偏离了最开始的方向,地图和刷一刷功能做得没那么好,外卖订单 ...
- Python爬取中国知网文献、参考文献、引证文献
前两天老师派了个活,让下载知网上根据高级搜索得到的来源文献的参考文献及引证文献数据,网上找了一些相关博客,感觉都不太合适,因此特此记录,希望对需要的人有帮助. 切入正题,先说这次需求,高级搜索,根据中 ...
- IE播放音频踩坑之路---待修改
在其他浏览器都是兼容的!在IE9就是显示一个黑色的框上面有个X 音乐无法播放 要显示播放界面的话,要添加 controls 属性(控件属性)例子:<audio src="xxx.m ...
- MySQL常用内置函数整理
[1]@@datadir 函数作用:返回数据库的存储目录构造SQL语句 select @@datadir;ps:@@basedir返回mysql的根目录[2]@@version_compile_os ...
- Sentry 企业级数据安全解决方案 - Relay PII 和数据清理
本文档描述了一种我们希望最终对用户隐藏的配置格式.该页面仍然存在的唯一原因是当前 Relay 接受这种格式以替代常规数据清理设置. 以下文档探讨了 Relay 使用和执行的高级数据清理配置的语法和语义 ...
- JavaScript创建和获取时间的方法
一.获取时间常用方法 1.创建时间对象 var time=new Date() //创建当前的时间信息对象 var time1=new Date(2022,1,1,10,25,30) //创建2022 ...