本章主要记录讲解并发线程的线程池。java.util.concurrent工具包里面的工具类。

一:Executor框架:

    Executors创建线程池的方法:

      

  1. newFixedThreadPool()方法: 该方法返回一个固定数量的线程池,该方法的线程数始终不变,当有一个任务提交时,若线程池中空闲,则立即执行,若没有,则会被暂缓在一个任务队列中等待有空闲的线程去执行。
  2.  
  3. newSingleThreadExecutor()方法:创建一个线程的线程池,若空闲则执行。若没有,则暂缓在任务队列中。
  4.  
  5. newCachedThreadPool()方法:返回一个可根据实际情况调整线程个数的线程池,不限制最大线程数量,若用空闲的线程则执行任务,若无任务则不创建线程,并且每一个空闲线程会在60秒后自动回收。
  6.  
  7. newScheduledThreadPool()方法:该方法返回一个SchededExecutorService对象,但该线程池可以指定线程的数量。
  8.  
  9. newFixedThreadPool使用心得:因为该方法创建的是一个固定的线程池,底层运用的队列是linkBlockingQueue队列,该队列是阻塞无序队列,所以切记,当首次任务列队完成调度后,后面的顺序就会被打乱,排序则需要根据指定的规则排序。
  10.  
  11. newCachedThreadExecutor使用心得:创建一个可缓存线程池,如果线程池长度超过处理需要,可灵活回收空闲线程,若无可回收,则新建线程。
  12.  
  13. newSingleThreadExecutor使用心得:创建一个单线程化的线程池,它只会用唯一的工作线程来执行任务,保证所有任务按照指定顺序(FIFO, LIFO, 优先级)执行。
  14.  
  15. newScheduledThreadPool使用心得:创建一个定长线程池,支持定时及周期性任务执行。

     

    代码解析:

       

  1. 1  //Task内部类:  
  2. 2
  3. 3         class Task extends Thread{
  4. 4
  5. 5         private int TaskId;
  6. 6
  7. 7         public Task(Integer TaskId){
  8. 8         this.TaskId=TaskId;
  9. 9         }
  10. 10           @Override
  11. 11           public void run() {
  12. 12             long start = System.currentTimeMillis();
  13. 13             try {
  14. 14               System.out.println("Run-----" +"TaskId:"+TaskId);
  15. 15               //模仿处理数据需要5s
  16. 16               Thread.sleep(5000);
  17. 17               long end = System.currentTimeMillis() - start;
  18. 18               System.out.println(" 执行时间:" + end);
  19. 19               } catch (InterruptedException e) {
  20. 20                 // TODO Auto-generated catch block
  21. 21                 e.printStackTrace();
  22. 22               }
  23. 23
  24. 24               }
  25. 25           }
  26. 26
  27. 27

      

  1. 1 // newFixedThreadPool方法测试:
  2. 2
  3. 3             
  4. 4
  5. 5           /**
  6. 6           * newFixedThreadPool线程池测试 创建一个定长线程池,可控制线程最大并发数,超出的线程会在队列中等待。队列无序
  7. 7           * @throws InterruptedException
  8. 8           */
  9. 9           private static void FixedThredPoolTest() throws InterruptedException {
  10. 10             System.out.println("newFixedThreadPool线程池测试-------------------");
  11. 11             //创建固定的10个线程的线程池 队列阻塞无序
  12. 12             ExecutorService pool=Executors.newFixedThreadPool(10);
  13. 13             /**
  14. 14             * 这里产生15个任务 看是否一次性处理10个任务,
  15. 15             * 然后5个任务阻塞放在LinkBlockingQueue队列里面,
  16. 16             * 然后等10个任务处理完在执行
  17. 17             */
  18. 18               for (int i = 1; i <= 15; i++) {
  19. 19                 // 执行给定的命令 执行任务
  20. 20                 pool.execute(new Task(i));
  21. 21                 }
  22. 22
  23. 23                 //关闭启动线程
  24. 24                 pool.shutdown();
  25. 25                 // 等待子线程结束,再继续执行下面的代码
  26. 26                 pool.awaitTermination(Long.MAX_VALUE, TimeUnit.DAYS);
  27. 27                 System.out.println("all thread complete");
  28. 28               }
  29. 29
  30. 30         

      

  1. 1  // newCachedThreadPool方法测试:
  2. 2
  3. 3             
  4. 4
  5. 5            /**
  6. 6            * newCachedThreadPool线程池测试 创建一个可缓存线程池,如果线程池长度超过处理需要,可灵活回收空闲线程,若无可回收,则新建线程。
  7. 7            * @throws InterruptedException
  8. 8            */
  9. 9            private static void CachedThreadPoolTest() throws InterruptedException {
  10. 10               System.out.println("newCachedThreadPool线程池测试-------------------");
  11. 11               ExecutorService pool=Executors.newCachedThreadPool();
  12. 12
  13. 13                 for (int i =1; i <= 10; i++) {
  14. 14                   // 执行给定的命令
  15. 15                   pool.execute(new Task(i));
  16. 16                 }
  17. 17                 //关闭启动线程
  18. 18                 pool.shutdown();
  19. 19                 // 等待子线程结束,再继续执行下面的代码
  20. 20                 pool.awaitTermination(Long.MAX_VALUE, TimeUnit.DAYS);
  21. 21                 System.out.println("all thread complete");
  22. 22               }
  23. 23
  24. 24

       

  1. 1 // newSingleThreadExecutor方法测试:
  2. 2
  3. 3         
  4. 4
  5. 5             /**
  6. 6
  7. 7             * newSingleThreadExecutor测试:创建一个单线程化的线程池,它只会用唯一的工作线程来执行任务,保证所有任务按照指定顺序(FIFO, LIFO, 优先级)执行。
  8. 8             * @throws InterruptedException
  9. 9             */
  10. 10             private static void SingleThreadPoolTest() throws InterruptedException {
  11. 11               System.out.println("newSingleThreadExecutor线程池测试-------------------");
  12. 12               ExecutorService pool=Executors.newSingleThreadExecutor();
  13. 13                 for (int i = 1; i <= 5; i++) {
  14. 14                   // 执行给定的命令
  15. 15                   pool.execute(new Task(i));
  16. 16                   }
  17. 17                 //关闭启动线程
  18. 18                 pool.shutdown();
  19. 19                 // 等待子线程结束,再继续执行下面的代码
  20. 20                 pool.awaitTermination(Long.MAX_VALUE, TimeUnit.DAYS);
  21. 21                 System.out.println("all thread complete");
  22. 22               }
  23. 23
  24. 24

      

  1. 1  // newScheduledThreadPool方法测试:
  2. 2
  3. 3           
  4. 4
  5. 5           /**
  6. 6           * newScheduledThreadPool测试 创建一个定长线程池,支持定时及周期性任务执行。
  7. 7           */
  8. 8           private static void ScheduledThreadPoolTest() {
  9. 9             System.out.println("newScheduledThreadPool线程池测试-------------------");
  10. 10             ScheduledExecutorService scheduler = Executors.newScheduledThreadPool(1);
  11. 11             /* 参数:
  12. 12             command - 要执行的任务
  13. 13             initialdelay - 首次执行的延迟时间
  14. 14             delay - 一次执行终止和下一次执行开始之间的延迟
  15. 15             unit - initialdelay 和 delay 参数的时间单位*/
  16. 16             ScheduledFuture<?> scheduleTask = scheduler.scheduleWithFixedDelay(new Task(1), 5, 1, TimeUnit.SECONDS);
  17. 17           }
  18. 18
  19. 19   

 

    

java架构《并发线程高级篇一》的更多相关文章

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

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

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

    本章主要记录讲解并发线程的线程池.使用Executor框架自定义线程池. 自定义线程池使用Queue队列所表示出来的形式: 1 ArrayBlockingQueue<Runnable>(3 ...

  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. cornerstoneTools 作用,用法,api使用心得

    一.cornerstoneTools的用途 1.作用可以响应一些事件,例如鼠标按下的事件,鼠标滚轮的事件或按键或触摸事件 2.可以对视口进行缩放平移 3.可以在图像上绘制图形 4.可以在图像上绘制文本 ...

  2. Linux 设置静态IP

    由于工作需要,安装一套Linux系统.安装完成后发现这个家伙居然不能上网,然后看了下IP,(命令 ip a)发现是127.0.0.1 下面是我的界面: inet 是127.0.0.1/8 还有6个网卡 ...

  3. 数仓建设中最常用模型--Kimball维度建模详解

    数仓建模首推书籍<数据仓库工具箱:维度建模权威指南>,本篇文章参考此书而作.文章首发公众号:五分钟学大数据,公众号中发送"维度建模"即可获取此书籍第三版电子书 先来介绍 ...

  4. Ubuntu 18.04.4 系统优化

    1 ) 允许root远程登录: sudo apt install vim git net-tools openssh-server sudo vim /etc/ssh/sshd_config .... ...

  5. session、cookie、token的区别

    从安全性优先级来说: 1.优先级 Cookie<session<token 2. 安全性 Cookie: ①cookie不是很安全,别人可以分析存放在本地的cookie并进行cookie欺 ...

  6. Hadoop 专栏 - MapReduce 入门

    MapReduce的基本思想 先举一个简单的例子: 打个比方我们有三个人斗地主, 要数数牌够不够, 一种最简单的方法可以找一个人数数是不是有54张(传统单机计算); 还可以三个人各分一摞牌数各自的(M ...

  7. Spring Boot(IDEA,Gradle)超详细用户管理项目(一)——Hello World

    1.构建工具的配置(Gradle):自定义-所有设置:构建.执行.部署-构建工具-Gradle: 设置Gradle用户主目录:(该目录相当于仓库,gradle将下载所需依赖到此目录下),此目录下可新建 ...

  8. 容器化安装Mysql 8.0 并部署主从复制

    系统: Centos 7.4 数据库版本:8.0.20 两台机器做相同操作 安装Docker export VERSION=18.06 && curl -fsSL http://rai ...

  9. Tensorflow-线性回归与手写数字分类

    线性回归 步骤 构造线性回归数据 定义输入层 设计神经网络中间层 定义神经网络输出层 计算二次代价函数,构建梯度下降 进行训练,获取预测值 画图展示 代码 import tensorflow as t ...

  10. ovs-vsctl命令

    ovs-vsctl [options] -- [options] command [args] [-- [options] command [args]]... 通过连接到 ovsdb-server ...