博客
关于我
Java自定义线程池来模拟银行办理业务场景来解析ThreadPoolExecutor的七大参数和四大拒绝策略
阅读量:370 次
发布时间:2019-03-05

本文共 1815 字,大约阅读时间需要 6 分钟。

1.在阿里巴巴开发手册中指出不允许使用 Executors 去创建,而是通过 ThreadPoolExecutor 的方式,所以大部分我们都是使用ThreadPoolExecutor

在这里插入图片描述
2.使用ThreadPoolExecutor 那么就得知道七大参数
在这里插入图片描述
3.四种拒绝策略
在这里插入图片描述
4.正常银行办理业务场景
在这里插入图片描述
解析:这里只开了两个窗口办理业务,当客户来办理时只能在这两个窗口办理业务,人越来越多,就会在候客区等待,依次办理业务

5.假设有一天要办理的客户超级多

在这里插入图片描述
解析:当客户很多是,那么银行就会开启其他几个窗口,当窗口人数已满,候客区也满了,这时候还有客户来办理业务,那么银行就会采取拒绝措施(这里只是虚拟,正常银行不会这么干,只是客户自己会选择离开)

6.Java自定义线程池来模拟银行办理业务场景

package com.kuang.threadpool;import java.util.concurrent.Executors;import java.util.concurrent.LinkedBlockingQueue;import java.util.concurrent.ThreadPoolExecutor;import java.util.concurrent.TimeUnit;public class ThreadPoolExecutorDemo {       public static void main(String[] args) {           ThreadPoolExecutor threadPool = new ThreadPoolExecutor(                2,//开启的窗口                5,//最多的窗口                2,//超时的时间                TimeUnit.SECONDS,//超时的单位                new LinkedBlockingQueue<>(3),//候客区                Executors.defaultThreadFactory(),//创建线程的工厂                new ThreadPoolExecutor.DiscardOldestPolicy()//银行的拒绝策略        );        try {               //最大承载:Deque + max            //超过 RejectedExecutionException            for (int i = 1; i <= 9; i++) {                   threadPool.execute(()->{                       System.out.println(Thread.currentThread().getName()+" ok");                });            }        } catch (Exception e) {               e.printStackTrace();        } finally {               threadPool.shutdown();        }    }}

测试结果:当1~5人办理业务时只会在第一和第二个窗口进行办理

在这里插入图片描述
测试结果:当6~8人办理业务是,就会开启5个窗口办理业务
在这里插入图片描述
测试结果:当超过8人时,银行就会采取拒绝策略(这里采用抛出异常)
在这里插入图片描述
7.七大参数提取

ThreadPoolExecutor threadPool = new ThreadPoolExecutor(     2,//开启的2个窗口     5,//最多的窗口     2,//超时的时间,就是超过一定时间,其他3个窗口就会关闭    TimeUnit.SECONDS,//超时的单位    new LinkedBlockingQueue<>(3),//候客区    Executors.defaultThreadFactory(),//创建线程的工厂    new ThreadPoolExecutor.DiscardOldestPolicy()//银行的拒绝策略  );

转载地址:http://myhg.baihongyu.com/

你可能感兴趣的文章
MySQL 中开启二进制日志(Binlog)
查看>>
MySQL 中文问题
查看>>
MySQL 中日志的面试题总结
查看>>
mysql 中的all,5分钟了解MySQL5.7中union all用法的黑科技
查看>>
Mysql 中的日期时间字符串查询
查看>>
MySQL 中锁的面试题总结
查看>>
MySQL 中随机抽样:order by rand limit 的替代方案
查看>>
MySQL 为什么需要两阶段提交?
查看>>
mysql 为某个字段的值加前缀、去掉前缀
查看>>
mysql 主从
查看>>
mysql 主从 lock_mysql 主从同步权限mysql 行锁的实现
查看>>
mysql 主从互备份_mysql互为主从实战设置详解及自动化备份(Centos7.2)
查看>>
mysql 主从关系切换
查看>>
mysql 主键重复则覆盖_数据库主键不能重复
查看>>
Mysql 优化 or
查看>>
mysql 优化器 key_mysql – 选择*和查询优化器
查看>>
MySQL 优化:Explain 执行计划详解
查看>>
Mysql 会导致锁表的语法
查看>>
mysql 使用sql文件恢复数据库
查看>>
mysql 修改默认字符集为utf8
查看>>