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. 洛谷 P4568 [JLOI2011]飞行路线

    题目描述 Alice和Bob现在要乘飞机旅行,他们选择了一家相对便宜的航空公司.该航空公司一共在n个城市设有业务,设这些城市分别标记为0到n-1,一共有m种航线,每种航线连接两个城市,并且航线有一定的 ...

  2. POJ_2480 Longge's problem【积性函数+欧拉函数的理解与应用】

    题目: Longge is good at mathematics and he likes to think about hard mathematical problems which will ...

  3. 【总结】ettercap工具之arp欺骗

    kali自带工具ettercap,使用前先开启IP转发功能 echo 1 > /proc/sys/net/ipv4/ip_forward 1.以管理员身份打开ettercap,两种方式-G图形化 ...

  4. select 点击的时候获取 value值

    <select onchange="selectUrl1(this.options[this.options.selectedIndex].value);">      ...

  5. (转)PEP 8——Python编码风格指南

    PEP 8——Python编码风格指南标签(空格分隔): Python PEP8 编码规范原文:https://lizhe2004.gitbooks.io/code-style-guideline-c ...

  6. Apache Beam中的函数式编程理念

    不多说,直接上干货! Apache Beam中的函数式编程理念 Apache Beam的编程范式借鉴了函数式编程的概念,从工程和实现角度向命令式妥协. 编程的领域里有三大流派:函数式.命令式.逻辑式. ...

  7. TOJ 3031 Multiple

    Description a program that, given a natural number N between 0 and 4999 (inclusively), and M distinc ...

  8. ArcGIS发布地图服务后直接调用查看方法

    做项目配置了一个地理底图,不知道有没有问题,如何给到客户查看并确认呢? 首先在ArcGIS上发布该地图: 打开地图后->文件->共享为->服务…… 发布成功后,得到可以访问的地图服务 ...

  9. word 摘要

    word 使用心得 定义快捷键 Tools -> Customize keyboard 自定义快捷键 cmd + L, 左对齐; cmd + R, 右对齐; cmd + E, 居中对齐 cmd ...

  10. HDU 5596 ——GTW likes gt——————【想法题】

    GTW likes gt Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 131072/131072 K (Java/Others)To ...