阻塞队列:
入队列的时候如果队列满了就会产生阻塞 等待其他线程调用出队列操作 队列中有空位之后才会继续入队列
出队列的时候如果队列空了就会产生阻塞 等待其他线程调用入队列操作 队列中有元素了之后才会出队列
代码示例:
[注意] :size前加上volatile
结果演示:
情况一:
情况2
生产者生产的差不多之后 生产者和消费者才会同步运行
改进方式:
建议:优先使用while搭配notifyAll
**
定时器
**
实现步骤:
但是上述代码会产生"忙等" 此时借助wait(time)方法就会解决这个问题,但是忙等也是有上限的 如果有notify就会提前唤醒没有的话到时间就会唤醒 代码阻塞在wait的过程中会避免频繁的占用CPU.
使用o来辅助实现wait方法
具体分析:
线程池:
已经包含了一些线程让我们直接去使用 避免频繁创建/销毁线程带来的开销
核心操作:
execute:任务加到线程池中
shutdown:销毁线程池中的所有线程
组成部分:(执行的任务+执行任务的线程)
1.有一个类描述线程具体干啥活 Runnable
2.有一个数据结构来组织若干个类 BolckingQueue
3.先有一个类表示工作线程
4.再有一个数据结构来组织若干个线程
关于线程池的基本概述导图及系列主要方法: