本章主要记录讲解并发线程的线程池。使用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架构《并发线程高级篇二》的更多相关文章

  1. java架构《并发线程高级篇四》

    本章主要讲并发线程的常见的两种锁.重入锁和读写锁 一:重入锁(ReentrantLock) 概念:重入锁,在需要进行同步的代码加锁,但最后一定不要忘记释放锁,否则会造成锁永远不能释放,其他线程进不了 ...

  2. java架构《并发线程高级篇一》

    本章主要记录讲解并发线程的线程池.java.util.concurrent工具包里面的工具类. 一:Executor框架: Executors创建线程池的方法: newFixedThreadPool( ...

  3. java架构《并发线程高级篇三》

    本章主要介绍和讲解concurrent.util里面的常用的工具类. 一.CountDownLatch使用:(用于阻塞主线程) 应用场景 :通知线程休眠和运行的工具类,是wait和notify的升级版 ...

  4. Java高并发 -- 线程池

    Java高并发 -- 线程池 主要是学习慕课网实战视频<Java并发编程入门与高并发面试>的笔记 在使用线程池后,创建线程变成了从线程池里获得空闲线程,关闭线程变成了将线程归坏给线程池. ...

  5. Java高并发--线程安全策略

    Java高并发--线程安全策略 主要是学习慕课网实战视频<Java并发编程入门与高并发面试>的笔记 不可变对象 发布不可变对象可保证线程安全. 实现不可变对象有哪些要注意的地方?比如JDK ...

  6. Java并发-线程池篇-附场景分析

    作者:汤圆 个人博客:javalover.cc 前言 前面我们在创建线程时,都是直接new Thread(): 这样短期来看是没有问题的,但是一旦业务量增长,线程数过多,就有可能导致内存异常OOM,C ...

  7. Java高并发与多线程(四)-----锁

    今天,我们开始Java高并发与多线程的第四篇,锁. 之前的三篇,基本上都是在讲一些概念性和基础性的东西,东西有点零碎,但是像文科科目一样,记住就好了. 但是本篇是高并发里面真正的基石,需要大量的理解和 ...

  8. Java之创建线程的方式四:使用线程池

    import java.util.concurrent.ExecutorService;import java.util.concurrent.Executors;import java.util.c ...

  9. java架构《并发线程中级篇》

    java多线程的三大设计模式 本章主要记录java常见的三大设计模式,Future.Master-Worker和生产者-消费者模式. 一.Future模式 使用场景:数据可以不及时返回,到下一次实际要 ...

随机推荐

  1. 【Linux】使用笔记

    前言 搜狗输入法,作为我体验最好的一个输入法,一直陪我从小学走到了现在,优麒麟线上发布会时,搜狗团队代表用"聪明"来形同它,事实也确实如此,它能十分人性地记录使用者常用的热词,并且 ...

  2. Node 跨域问题 Access to XMLHttpRequest at 'http://localhost:8080/api/user/login' from origin 'http://localhost:808

    人不可能踏进同一条河流,我可以一天在同一个问题上摔倒两次. 这次是跨域问题,都是泪,教程提供的服务端代码虽然配置了文件,但是依然是没有解决跨域问题,依然报错 Request header field ...

  3. flume集成kafka(kafka开启kerberos)配置

    根据flume官网:当kafka涉及kerberos认证: 涉及两点配置,如下: 配置一:见下实例中红色部分 配置conf实例: [root@gz237-107 conf]# cat flume_sl ...

  4. sql查询速度慢分析及如何优化查询

    原因分析后台数据库中数据过多,未做数据优化数据请求-解析-展示处理不当 网络问题提高数据库查询的速度方案SQL 查询速度慢的原因有很多,常见的有以下几种:1.没有索引或者没有用到索引(查询慢最常见的问 ...

  5. dhcp分发地址以及静态路由设置

    路由器R1配置: system-view [Huawei]sysname R1 [R1]user-interface console 0 [R1-ui-console0]idle-timeout 0 ...

  6. Mac使用HomeBrew

    前言 考虑许久终于决定入手mac耍耍,还是因为要找工作了,手上的win本大学入的,现在使用卡顿太多,另外就是mac作为程序员之友仰慕已久.决定在PDD入了.到手后发现mac真的跟win有很大差别.还是 ...

  7. python_元组(tuple)

    #tuple(),元组不可以修改,不能对其进行增加或删除操作,元组是有序的 #1.定义 tu_1 = () #定义一个空元组 tu_2 = (1,2,'alex',[3,4],(5,6,7),True ...

  8. 跟我一起学Redis之加个哨兵让主从复制更加高可用

    前言 主从复制的实现在上一篇已经分享过,虽然主从复制本身的确让读写分离更加高效,但是对于整体高可用存在很大的劣势:当主节点宕机了之后还需要人为重新进行主从关系配置:这不是开玩笑嘛,这样人为干预,故障恢 ...

  9. 分别使用 Python 和 Math.Net 调用优化算法

    1. Rosenbrock 函数 在数学最优化中,Rosenbrock 函数是一个用来测试最优化算法性能的非凸函数,由Howard Harry Rosenbrock 在 1960 年提出 .也称为 R ...

  10. 干电池1.5V升压3.3V芯片电路图

    1.5V升压3.3V的芯片 PW5100 是一款大效率.10uA低功耗.低纹波.高工作频率1.2MHZ的 PFM 同步升压 DC/DC 变换器.输入电压可低0.7V,输入电压范围0.7V-5V之间,输 ...