java架构《并发线程高级篇一》
本章主要记录讲解并发线程的线程池。java.util.concurrent工具包里面的工具类。
一:Executor框架:
Executors创建线程池的方法:
newFixedThreadPool()方法: 该方法返回一个固定数量的线程池,该方法的线程数始终不变,当有一个任务提交时,若线程池中空闲,则立即执行,若没有,则会被暂缓在一个任务队列中等待有空闲的线程去执行。 newSingleThreadExecutor()方法:创建一个线程的线程池,若空闲则执行。若没有,则暂缓在任务队列中。 newCachedThreadPool()方法:返回一个可根据实际情况调整线程个数的线程池,不限制最大线程数量,若用空闲的线程则执行任务,若无任务则不创建线程,并且每一个空闲线程会在60秒后自动回收。 newScheduledThreadPool()方法:该方法返回一个SchededExecutorService对象,但该线程池可以指定线程的数量。 newFixedThreadPool使用心得:因为该方法创建的是一个固定的线程池,底层运用的队列是linkBlockingQueue队列,该队列是阻塞无序队列,所以切记,当首次任务列队完成调度后,后面的顺序就会被打乱,排序则需要根据指定的规则排序。 newCachedThreadExecutor使用心得:创建一个可缓存线程池,如果线程池长度超过处理需要,可灵活回收空闲线程,若无可回收,则新建线程。 newSingleThreadExecutor使用心得:创建一个单线程化的线程池,它只会用唯一的工作线程来执行任务,保证所有任务按照指定顺序(FIFO, LIFO, 优先级)执行。 newScheduledThreadPool使用心得:创建一个定长线程池,支持定时及周期性任务执行。
代码解析:
1 //Task内部类:
2
3 class Task extends Thread{
4
5 private int TaskId;
6
7 public Task(Integer TaskId){
8 this.TaskId=TaskId;
9 }
10 @Override
11 public void run() {
12 long start = System.currentTimeMillis();
13 try {
14 System.out.println("Run-----" +"TaskId:"+TaskId);
15 //模仿处理数据需要5s
16 Thread.sleep(5000);
17 long end = System.currentTimeMillis() - start;
18 System.out.println(" 执行时间:" + end);
19 } catch (InterruptedException e) {
20 // TODO Auto-generated catch block
21 e.printStackTrace();
22 }
23
24 }
25 }
26
27
1 // newFixedThreadPool方法测试:
2
3
4
5 /**
6 * newFixedThreadPool线程池测试 创建一个定长线程池,可控制线程最大并发数,超出的线程会在队列中等待。队列无序
7 * @throws InterruptedException
8 */
9 private static void FixedThredPoolTest() throws InterruptedException {
10 System.out.println("newFixedThreadPool线程池测试-------------------");
11 //创建固定的10个线程的线程池 队列阻塞无序
12 ExecutorService pool=Executors.newFixedThreadPool(10);
13 /**
14 * 这里产生15个任务 看是否一次性处理10个任务,
15 * 然后5个任务阻塞放在LinkBlockingQueue队列里面,
16 * 然后等10个任务处理完在执行
17 */
18 for (int i = 1; i <= 15; i++) {
19 // 执行给定的命令 执行任务
20 pool.execute(new Task(i));
21 }
22
23 //关闭启动线程
24 pool.shutdown();
25 // 等待子线程结束,再继续执行下面的代码
26 pool.awaitTermination(Long.MAX_VALUE, TimeUnit.DAYS);
27 System.out.println("all thread complete");
28 }
29
30
1 // newCachedThreadPool方法测试:
2
3
4
5 /**
6 * newCachedThreadPool线程池测试 创建一个可缓存线程池,如果线程池长度超过处理需要,可灵活回收空闲线程,若无可回收,则新建线程。
7 * @throws InterruptedException
8 */
9 private static void CachedThreadPoolTest() throws InterruptedException {
10 System.out.println("newCachedThreadPool线程池测试-------------------");
11 ExecutorService pool=Executors.newCachedThreadPool();
12
13 for (int i =1; i <= 10; i++) {
14 // 执行给定的命令
15 pool.execute(new Task(i));
16 }
17 //关闭启动线程
18 pool.shutdown();
19 // 等待子线程结束,再继续执行下面的代码
20 pool.awaitTermination(Long.MAX_VALUE, TimeUnit.DAYS);
21 System.out.println("all thread complete");
22 }
23
24
1 // newSingleThreadExecutor方法测试:
2
3
4
5 /**
6
7 * newSingleThreadExecutor测试:创建一个单线程化的线程池,它只会用唯一的工作线程来执行任务,保证所有任务按照指定顺序(FIFO, LIFO, 优先级)执行。
8 * @throws InterruptedException
9 */
10 private static void SingleThreadPoolTest() throws InterruptedException {
11 System.out.println("newSingleThreadExecutor线程池测试-------------------");
12 ExecutorService pool=Executors.newSingleThreadExecutor();
13 for (int i = 1; i <= 5; i++) {
14 // 执行给定的命令
15 pool.execute(new Task(i));
16 }
17 //关闭启动线程
18 pool.shutdown();
19 // 等待子线程结束,再继续执行下面的代码
20 pool.awaitTermination(Long.MAX_VALUE, TimeUnit.DAYS);
21 System.out.println("all thread complete");
22 }
23
24
1 // newScheduledThreadPool方法测试:
2
3
4
5 /**
6 * newScheduledThreadPool测试 创建一个定长线程池,支持定时及周期性任务执行。
7 */
8 private static void ScheduledThreadPoolTest() {
9 System.out.println("newScheduledThreadPool线程池测试-------------------");
10 ScheduledExecutorService scheduler = Executors.newScheduledThreadPool(1);
11 /* 参数:
12 command - 要执行的任务
13 initialdelay - 首次执行的延迟时间
14 delay - 一次执行终止和下一次执行开始之间的延迟
15 unit - initialdelay 和 delay 参数的时间单位*/
16 ScheduledFuture<?> scheduleTask = scheduler.scheduleWithFixedDelay(new Task(1), 5, 1, TimeUnit.SECONDS);
17 }
18
19
java架构《并发线程高级篇一》的更多相关文章
- java架构《并发线程高级篇四》
本章主要讲并发线程的常见的两种锁.重入锁和读写锁 一:重入锁(ReentrantLock) 概念:重入锁,在需要进行同步的代码加锁,但最后一定不要忘记释放锁,否则会造成锁永远不能释放,其他线程进不了 ...
- java架构《并发线程高级篇二》
本章主要记录讲解并发线程的线程池.使用Executor框架自定义线程池. 自定义线程池使用Queue队列所表示出来的形式: 1 ArrayBlockingQueue<Runnable>(3 ...
- java架构《并发线程高级篇三》
本章主要介绍和讲解concurrent.util里面的常用的工具类. 一.CountDownLatch使用:(用于阻塞主线程) 应用场景 :通知线程休眠和运行的工具类,是wait和notify的升级版 ...
- Java高并发 -- 线程池
Java高并发 -- 线程池 主要是学习慕课网实战视频<Java并发编程入门与高并发面试>的笔记 在使用线程池后,创建线程变成了从线程池里获得空闲线程,关闭线程变成了将线程归坏给线程池. ...
- Java高并发--线程安全策略
Java高并发--线程安全策略 主要是学习慕课网实战视频<Java并发编程入门与高并发面试>的笔记 不可变对象 发布不可变对象可保证线程安全. 实现不可变对象有哪些要注意的地方?比如JDK ...
- Java并发-线程池篇-附场景分析
作者:汤圆 个人博客:javalover.cc 前言 前面我们在创建线程时,都是直接new Thread(): 这样短期来看是没有问题的,但是一旦业务量增长,线程数过多,就有可能导致内存异常OOM,C ...
- Java高并发与多线程(四)-----锁
今天,我们开始Java高并发与多线程的第四篇,锁. 之前的三篇,基本上都是在讲一些概念性和基础性的东西,东西有点零碎,但是像文科科目一样,记住就好了. 但是本篇是高并发里面真正的基石,需要大量的理解和 ...
- Java之创建线程的方式四:使用线程池
import java.util.concurrent.ExecutorService;import java.util.concurrent.Executors;import java.util.c ...
- java架构《并发线程中级篇》
java多线程的三大设计模式 本章主要记录java常见的三大设计模式,Future.Master-Worker和生产者-消费者模式. 一.Future模式 使用场景:数据可以不及时返回,到下一次实际要 ...
随机推荐
- 【转载】VUE的背景图引入
我现在的项目要将登录页面的背景引一图片做为背景图片,按原jsp中的写法,发现无法找到背景图片,最后从网上查资料,采用上面的写法,成功显示出背景图片,参考网址 https://blog.csdn.net ...
- 不想加班开发管理后台了,试试这个 Java 开源项目吧!
本文适合有 Java 基础并了解 SpringBoot 框架的同学 本文作者:HelloGitHub-嘉文 这里是 HelloGitHub 推出的<讲解开源项目>系列,今天给大家带来一款开 ...
- 看图知义,Winform开发的技术特点分析
整理一下自己之前的Winform开发要点,以图文的方式展示一些关键性的技术特点,总结一下. 1.主体界面布局 2.权限管理系统 3.工作流模块 4.字典管理 5.通用的附件管理模块 6.系统模块化开发 ...
- 风炫安全web安全学习第二十九节课 CSRF防御措施
风炫安全web安全学习第二十九节课 CSRF防御措施 CSRF防御措施 增加token验证 对关键操作增加token验证,token值必须随机,每次都不一样 关于安全的会话管理(SESSION) 不要 ...
- Nexus3.X在linux系统搭建maven私服
准备工作: 1.linux服务器上需安装jdk(非yum下来的open_jdk!!!,版本1.8以上) 2.linux服务器上需安装maven(如不会,请点击链接,maven版本自己喜欢就好) 准备工 ...
- vs code编写java
不知不觉中vs code变得非常强大了,今天小编就分享一下vs code编写java语言.其实除了java语言,还支持很多语言. 首先看下vs code欢迎页面支持哪些语言: 好家伙,支持的东西还真不 ...
- mysql错误:java.sql.SQLException: The server time zone value '�й���ʱ��' is unrecognized or represents more than one time zone.
java.sql.SQLException: The server time zone value '�й���ʱ��' is unrecognized or represents more tha ...
- Mac上最好用的软件集合,没有之一
前言 题主从 windows 系统换成 macOS 系统已经4年多了.对于没有用过 Mac 电脑的人来说,可能无法理解 Mac 好用在哪里.不过对于一个用过 Mac 的开发者来说,从 windows ...
- Flutter 布局类组件:弹性布局(Flex)
前言 弹性布局允许子组件按照一定比例来分配父容器空间,Flutter中的弹性布局主要通过Flex和Expanded来配合实现. Flex Flex组件可以沿着水平或垂直方向排列子组件,如果你知道主轴方 ...
- python函数3-函数嵌套/递归/匿名函数
2 .函数递归: 3.匿名函数