java架构《并发线程高级篇二》
本章主要记录讲解并发线程的线程池。使用Executor框架自定义线程池。
自定义线程池使用Queue队列所表示出来的形式:
1 ArrayBlockingQueue<Runnable>(3); 有界队列:
2
3 /**
4 * 在使用有界队列时,若有新的任务需要执行,如果线程池实际线程数小于corePoolSize,则优先创建线程,
5 * 若大于corePoolSize,则会将任务加入队列,
6 * 若队列已满,则在总线程数不大于maximumPoolSize的前提下,创建新的线程,
7 * 若线程数大于maximumPoolSize,则执行拒绝策略。或其他自定义方式。
8 */
9
10
11
12 LinkedBlockingQueue(); 无界队列:
13
14 /**
15
16 *当使用无界队列时,MaxSize则无效,只根据corePoolSize大小来创建线程
17
18 */
Executor自定义异常:
自定义异常类并实现RejectedExecutionHandler类
代码分解:
1 public class MyRejected implements RejectedExecutionHandler{
2
3
4 public MyRejected(){
5 }
6
7 @Override
8 public void rejectedExecution(Runnable r, ThreadPoolExecutor executor) {
9 System.out.println("自定义处理..");
10 System.out.println("当前被拒绝任务为:" + r.toString());
11 }
12
13 }
自定义异常代码解析:
MyTask类实现 Runnable:
1 public class MyTask implements Runnable {
2
3 private int taskId;
4 private String taskName;
5
6 public MyTask(int taskId, String taskName){
7 this.taskId = taskId;
8 this.taskName = taskName;
9 }
10
11 public int getTaskId() {
12 return taskId;
13 }
14
15 public void setTaskId(int taskId) {
16 this.taskId = taskId;
17 }
18
19 public String getTaskName() {
20 return taskName;
21 }
22
23 public void setTaskName(String taskName) {
24 this.taskName = taskName;
25 }
26
27 @Override
28 public void run() {
29 try {
30 System.out.println("run taskId =" + this.taskId);
31 Thread.sleep(5*1000);
32 //System.out.println("end taskId =" + this.taskId);
33 } catch (InterruptedException e) {
34 e.printStackTrace();
35 }
36 }
37
38 public String toString(){
39 return Integer.toString(this.taskId);
40 }
41
42 }
UseThreadPoolExecutor自定义线程池类:
1 public class UseThreadPoolExecutor{
2
3
4 public static void main(String[] args) {
5 /**
6 * 在使用有界队列时,若有新的任务需要执行,如果线程池实际线程数小于corePoolSize,则优先创建线程,
7 * 若大于corePoolSize,则会将任务加入队列,
8 * 若队列已满,则在总线程数不大于maximumPoolSize的前提下,创建新的线程,
9 * 若线程数大于maximumPoolSize,则执行拒绝策略。或其他自定义方式。
10 *
11 */
12 ThreadPoolExecutor pool = new ThreadPoolExecutor(
13 1, //coreSize
14 2, //MaxSize
15 60, //60
16 TimeUnit.SECONDS,
17 new ArrayBlockingQueue<Runnable>(3) //指定一种队列 (有界队列)
18 //new LinkedBlockingQueue<Runnable>()
19 , new MyRejected()
20 //, new DiscardOldestPolicy()
21 );
22
23 MyTask mt1 = new MyTask(1, "任务1");
24 MyTask mt2 = new MyTask(2, "任务2");
25 MyTask mt3 = new MyTask(3, "任务3");
26 MyTask mt4 = new MyTask(4, "任务4");
27 MyTask mt5 = new MyTask(5, "任务5");
28 MyTask mt6 = new MyTask(6, "任务6");
29
30 pool.execute(mt1);
31 pool.execute(mt2);
32 pool.execute(mt3);
33 pool.execute(mt4);
34 pool.execute(mt5);
35 pool.execute(mt6);
36
37 pool.shutdown();
38
39 }
40 }
java架构《并发线程高级篇二》的更多相关文章
- java架构《并发线程高级篇四》
本章主要讲并发线程的常见的两种锁.重入锁和读写锁 一:重入锁(ReentrantLock) 概念:重入锁,在需要进行同步的代码加锁,但最后一定不要忘记释放锁,否则会造成锁永远不能释放,其他线程进不了 ...
- java架构《并发线程高级篇一》
本章主要记录讲解并发线程的线程池.java.util.concurrent工具包里面的工具类. 一:Executor框架: Executors创建线程池的方法: newFixedThreadPool( ...
- 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模式 使用场景:数据可以不及时返回,到下一次实际要 ...
随机推荐
- reactor模式:多线程的reactor模式
上文说到单线程的reactor模式 reactor模式:单线程的reactor模式 单线程的reactor模式并没有解决IO和CPU处理速度不匹配问题,所以多线程的reactor模式引入线程池的概念, ...
- 伯俊BOS2.0关于订金单的处理方案
订金单功能调整设计 一. 功能确认 BPOS关于订金的使用对应的是"预收单",原"预收单"设置有商品明细,根据客户对订金的需求,取消原有"商品 ...
- 如何在Nginx不绑定域名下使用SSL/TLS证书?
前提 该文主要记录如何在没有购买域名的情况下使用SSL/TLS协议,即地址前面的http变成了https.但是这样的SSL协议是会被浏览器认为是不安全的.在开发或者测试环境可以这样搞,生产环境下还是乖 ...
- mysql的binlog+maxwell+kakka
1.业务库痛点及解决⽅案 初期出⾏业务的订单相关,是以mysql作为业务库为基准的,但是随着业务线增多,每⽇新增数据指 数上涨,⼏乎在每天的⾼峰期期间,都会出现业务库所在服务器的cpu.IO.内存等跑 ...
- [Java基础]——String类
此篇博客主要整理Java中的String类的使用. 一.String 1.1 String 的定义 上图是jdk中对String类的定义,得到的信息有: ①.String类声明为final的, ...
- 【SpringMVC】SpringMVC 实现文件上传
SpringMVC 实现文件上传 文章源码 文件上传回顾 查看 JavaWeb 阶段的文件上传下载 实现步骤: 客户端: 发送 post 请求,告诉服务器要上传什么文件 服务器: 要有一个 form ...
- docker 报错: Cannot connect to the Docker daemon at unix:///var/run/docker.sock.
最近在 Windows 子系统 WSL 上面安装了一个 ubuntu18.04, 安装完docker 跑 hello-world 的时候报错了 docker: Cannot connect to th ...
- mysqldump 的-T参数
/usr/local/mysql/bin/mysqldump -uroot -T /tmp lina xuehao 把lina数据库中的xuehao表在tmp目录下备份出来两个文件,一个是纯数据.tx ...
- CodeMonke少儿编程第1章 step与turn
第1章 step与turn 目标 了解游戏舞台的各组成部分 掌握step和turn指令的用法 说起计算机,对于不了解它的人来说,也许会感到有些神秘,其实不然,它不过是能够接收指令并且按照指令执行的一种 ...
- ctfhub技能树—sql注入—整数型注入
打开靶机 查看页面信息 查看回显位 查询数据库名 查询表名 查询字段 查询字段信息 使用sqlmap食用效果更佳 查数据库名 python2 sqlmap.py -u http://challenge ...