1、 线程池

   就好生活中的游泳池,可以容纳多人在池子里游泳、戏水。线程池里可以有多个正在运行的线程,同时执行已经提交了的多个任务。

      

  什么是线程池?一个用来创建和管理线程的容器。

          

  • 线程池的原理

    线程复用

  • 线程池好处

    1、降低了资源的消耗,避免了频繁创建和销毁线程带来的系统开销

    2、提高了响应速度

    3、可以更好的管理线程的数量

       1.1 线程池的使用:提交了Runnable任务

    1.1.1 如何获得线程池

通过该类的静态方法可以创建线程池对象,该方法如下:

public static ExecutorService newFixedThreadPool​(int nThreads)  //创建线程池对象并制定线程数量

    参数 ExecutorService: 该接口的实现类对象就是一个线程池对象   

    ExecutorService常用方法:

      Future<?> submit​(Runnable task)   

提交一个可运行的任务执行,并返回一个表示该任务的Future。

   1.1.2 销毁线程池

     void shutdown​()  //销毁线程池,会等待线程池中所有的任务执行完毕之后再销毁

      shutdownNow​()  //立即销毁线程池,如果还没有开始执行的任务就不会执行

 

  1.2 线程池的使用:提交了Runnable任务

  • 通过工具类ExecutorService调用静态方法:newFixedThreadPool创建线程池对象并制定线程的数量。

  • 创建一个类实现Runnable接口,重写run方法,将线程任务相关的代码写在run方法中

  • 调用线程池对象的submit方法,提交任务

  • 关闭线程池(一般不做)

  1.3 线程池的使用:提交了Callable任务

  • 通过工具类ExecutorService调用静态方法:newFixedThreadPool创建线程池对象并制定线程的数量。

  • 创建一个类实现Callable接口,重写call方法,将线程任务相关的代码写在call方法中

  • 调用线程池对象的submit方法,提交任务

  • 关闭线程池(一般不做)

  1.4 Callable接口和Runnable接口的区别:

    Callable接口中call方法有返回值,可以声明异常

    Runnable接口中的run方法没有返回值,不能声明异常(编译时异常)

  1.5 Callable接口和Runnable接口选择:

  判断任务执行完毕之后是否需要有一个返回值给调用者。如果需要,选择Callable;如果不需要,两个都可以。

2、 线程等待与唤醒机制概述

又称为线程间通信两个或多个线程在执行任务过程中相互协作共同完成任务。

      2.1 线程等待与唤醒机制相关方法

void wait();     //等待,让当前正在执行的线程释放CPU使用权,进入等待状态

void notify():  //唤醒,随机唤醒一个正在等待的线程,让其进入可运行状态

void notifyAll();      //唤醒所有正在等待的线程,让其进入可运行状态

这三个方法必须由锁对象调用且必须在同步代码块或同步方法中调用。

3、 Lambda表达式

  3.1 Lambda表达式概述

    

函数式编程思想的体现。函数式编程思想则尽量忽略面向对象的复杂语法——强调做什么,而不是以什么形式做。

  Lambda表达式是JDK1.8新特性

  Lambda表达式可以简化匿名内部类复杂代码编写。只专注做什么,而不是怎么做。

  3.2 Lambda 表达式格式

                  

    3.2.1 Lambda表达式的标准格式:

      3.2.1.1 格式:(数据类型 参数…) -> {//方法体},也叫匿名函数

      说明:

      ():等价于方法的参数列表

      -> :新语法,固定写法,代表指向,小括号中参数可以在方法体中使用

      {}:等价于方法体

      3.2.1.2 Lambda表达式的使用前提条件:

       必须是接口且接口中只有一个抽象方法

      3.2.1.3 Lambda表达式的原理:

        创建了接口的实现类对象,重写了接口中的抽象方法

    3.2.2 Lambda表达式省略格式:

    格式:(参数…) -> {//方法体}

     省略规则如下:

      小括号中的参数类型可以省略,不管有几个参数

      如果小括号中只有一个参数,可以省略小括号

      如果方法体中只有一条语句,则可以省略大括号;如果省略了大括号,则return语句和分号必须要省略。

4. 使用线程注意事项

  • 把多线程共享的数据、变量放在类里面的成员变量里去定义,且定义成static。

  • 把各个线程私有的统计数据、变量放在run方法里面定义。这是因为各个线程是new 出来的,都拥有各自run方法里面的局部变量。

day007-线程池、Lambda的更多相关文章

  1. 等待唤醒机制----线程池----lambda表达式

    1.等待唤醒机制 1.1线程间通信 概念:多个线程在处理同一个资源,但是处理的动作(线程的任务)却不相同. 比如:线程A用来生成包子的,线程B用来吃包子的,包子可以理解为同一资源,线程A与线程B处理的 ...

  2. 01 语言基础+高级:1-7 异常与多线程_day07 【线程池、Lambda表达式】

    day07[线程池.Lambda表达式] 主要内容 等待与唤醒案例 线程池 Lambda表达式 教学目标 -[ ] 能够理解线程通信概念-[ ] 能够理解等待唤醒机制-[ ] 能够描述Java中线程池 ...

  3. 328 day07线程池、Lambda表达式

    day07[线程池.Lambda表达式] 主要内容 等待与唤醒案例 线程池 Lambda表达式 教学目标 -[ ] 能够理解线程通信概念 -[ ] 能够理解等待唤醒机制 -[ ] 能够描述Java中线 ...

  4. Java线程池 与Lambda

    七.线程池.Lambda 1.1基本概念: ​ 线程池:其实就是一个容纳多个线程的容器,其中的线程可以反复使用,省去了频繁创建线程对象的操作,无需反复创建线程而消耗过多的资源. 1.2线程池的好处: ...

  5. Java之线程池和Lambda表达式

    线程池和lambda表达式 学习线程池和lambda表达式的理解 补充一个知识点(单例设计模式) 在多线程中,我们只需要一个任务类,为了防止创建多个任务类,这个时候就需要用到单例模式,单例模式有两种设 ...

  6. 线程池、Lambda表达式

    线程池.Lambda表达式 线程池.Lambda表达式 线程池.Lambda表达式 线程池.Lambda表达式 线程池.Lambda表达式 线程池.Lambda表达式 线程池.Lambda表达式 (正 ...

  7. 线程池和lambda表达式

    线程池1.什么是线程池.一个用来创建和管理线程的容器;2.线程池的作用.提高线程的复用性,降低资源消耗提高线程的响应速度,提高线程的可管理性3.线程的核心思想;线程的复用 4.线程池的创建Execut ...

  8. JavaSE学习笔记(13)---线程池、Lambda表达式

    JavaSE学习笔记(13)---线程池.Lambda表达式 1.等待唤醒机制 线程间通信 概念:多个线程在处理同一个资源,但是处理的动作(线程的任务)却不相同. 比如:线程A用来生成包子的,线程B用 ...

  9. Java【线程池、Lambda表达式】

    见pdf 等待唤醒机制 wait和notify 第二章 线程池 如果并发的线程数量很多,并且每个线程都是执行一个时间很短的任务就结束了,这样频繁创建线程就会大大降低 系统的效率,因为频繁创建线程和销毁 ...

  10. C#多线程之线程池篇3

    在上一篇C#多线程之线程池篇2中,我们主要学习了线程池和并行度以及如何实现取消选项的相关知识.在这一篇中,我们主要学习如何使用等待句柄和超时.使用计时器和使用BackgroundWorker组件的相关 ...

随机推荐

  1. Linux误挂载到根目录出现问题!!!!!!!!!!!!!!!

    一.背景: 因根目录/空间不大,故而想将另一硬盘挂载到根目录下(后发现此想法很是幼稚): 二.过程: 1.成功输入命令挂载后,发现出现/上被挂了两个东西,且/下剩余空间还是原来一样大,才发现大错特错: ...

  2. kafka producer参数详解

    https://my.oschina.net/u/218540/blog/1794669/

  3. PIE SDK过滤

    1. 算法功能简介 过滤功能使用斑点分组方法来消除分类文件中被隔离的分类像元,用以解决分类图像中出现的孤岛问题. PIE SDK支持算法功能的执行,下面对过滤算法功能进行介绍. 2. 算法功能实现说明 ...

  4. html自定义垂直导航菜单(加强版--自定义传入menu参数,支持JSONArray、JSArray、JSONObject、JSObject)

    在上一篇中我简单写了个html自定义垂直导航菜单,缺点很明显,里面的数据是固定死的,不能动态更改数据. 这里我重写了一个修改版的垂直二级导航菜单,将原先的menuBox.init(config);修改 ...

  5. Rsa2加密报错java.security.spec.InvalidKeySpecException的解决办法

    最近在和支付宝支付做个对接,Java项目中用到了RSA2进行加解密,在加密过程中遇到了错误: java.security.spec.InvalidKeySpecException: java.secu ...

  6. SpringBoot 思维导图

  7. SQLAlchemy安装和使用

    1.SQLAlchemy安装 SQLAlchemy依赖mysql-python驱动,mysql-python目前只有支持py2的版本和mysql5.5的版本 点我:mysql-python链接 版本: ...

  8. 数据段描述符和代码段描述符(二)——《x86汇编语言:从实模式到保护模式》读书笔记11

    这篇博文,我们编写一个C语言的小程序,来解析数据段或者代码段描述符的各个字段.这样我们阅读原书的代码就会方便一点,只要运行这个小程序,就可以明白程序中定义的数据段或者代码段的描述符了. 这段代码,我用 ...

  9. java collection与数组(Array)互转

    先确定几个概念,这里说的数组元素,除基本类型数组外,并非指元素对象本身,而是它们的引用.换句话说,基本数组的元素是数值本身,非基本数组的元素都是一个地址(对应指针). 1.collection的元素不 ...

  10. HZAU 18——Array C——————【贪心】

    18: Array C Time Limit: 1 Sec  Memory Limit: 128 MBSubmit: 586  Solved: 104[Submit][Status][Web Boar ...