JAVA学习之等待与唤醒案例线程池Lambda表达式

Posted honghui-cai

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了JAVA学习之等待与唤醒案例线程池Lambda表达式相关的知识,希望对你有一定的参考价值。

第一章 等待唤醒机制

 

1.1 线程间通信

多个线程在处理同一个资源,但是处理的动作(线程的任务)却不相同,多个线程之间的协同通信。

 

 

 

1.2 等待唤醒机制

等待唤醒机制就是用于解决线程间通信的问题的,使用到的3个方法的含义如下:

  1. wait:线程不再活动,不再参与调度,进入 wait set 中,因此不会浪费 CPU 资源,也不会去竞争锁了,这时的线程状态即是 WAITING。它还要等着别的线程执行一个特别的动作,也即是“通知(notify)”在这个对象上等待的线程从wait set 中释放出来,重新进入到调度队列(ready queue)中

  2. notify:则选取所通知对象的 wait set 中的一个线程释放;例如,餐馆有空位置后,等候就餐最久的顾客最先入座。

  3. notifyAll:则释放所通知对象的 wait set 上的全部线程。

注意:

哪怕只通知了一个等待的线程,被通知线程也不能立即恢复执行,因为它当初中断的地方是在同步块内,而此刻它已经不持有锁,所以她需要再次尝试去获取锁(很可能面临其它线程的竞争),成功后才能在当初调用 wait 方法之后的地方恢复执行。

总结如下:

  • 如果能获取锁,线程就从 WAITING 状态变成 RUNNABLE 状态;

  • 否则,从 wait set 出来,又进入 entry set,线程就从 WAITING 状态又变成 BLOCKED 状态

 

调用wait和notify方法需要注意的细节

  1. wait方法与notify方法必须要由同一个锁对象调用。因为:对应的锁对象可以通过notify唤醒使用同一个锁对象调用的wait方法后的线程。

  2. wait方法与notify方法是属于Object类的方法的。因为:锁对象可以是任意对象,而任意对象的所属类都是继承了Object类的。

  3. wait方法与notify方法必须要在同步代码块或者是同步函数中使用。因为:必须要通过锁对象调用这2个方法。

 

1.3 生产者与消费者问题

 


 

第二章 线程池

 技术图片

 

 

2.1 线程池的使用

技术图片

 

 

 

 

 


 

 

 

第三章 Lambda表达式

技术图片

 

以上是关于JAVA学习之等待与唤醒案例线程池Lambda表达式的主要内容,如果未能解决你的问题,请参考以下文章

线程池,lambda表达式

线程池 Lambda表达式 - 10

Java学习之多线程二

Java线程池主线程等待子线程的方法

Java线程池主线程等待子线程的方法

Java线程池主线程等待子线程的方法