【零基础学java】(等待唤醒机制,线程池补充)

等待唤醒机制

生产者和消费者(常见方法)
void wait()当前线程等待,直到被其他线程唤醒
void notify()随机唤醒单个线程
void notifyAll()唤醒所有线程

等待唤醒机制的阻塞队列方式实现

put数据时:放不进去会等着,叫做阻塞

take数据时:取出第一个,取不到的等着

线程的六种状态

线程池

线程池的作用

1减少线程创建和销毁的开销

  • 问题:每次需要任务时都创建新线程,完成后立即销毁,会消耗大量CPU和内存资源。

  • 解决 :线程池复用已创建的线程,避免频繁创建/销毁。

2. 控制并发.数量,防止系统过载

  • 问题:无限制创建线程可能导致:

    • 内存耗尽

    • CPU过度切换(上下文切换开销大)

    • 系统不稳定

  • 解决 :线程池设置最大线程数,控制同时运行的线程数量。

3. 提高响应速度

  • 任务到达时,通常已有空闲线程可以立即执行,无需等待线程创建。

4. 统一管理线程生命周期

  • 提供统一的调度、监控和资源回收机制。

二、核心作用

1. 资源复用

  • 线程作为系统稀缺资源,重复使用已创建线程。

  • 类似数据库连接池,避免频繁申请释放。

2. 流量控制(削峰填谷)

  • 当突发大量请求时,线程池通过队列缓冲:

    • 核心线程 → 队列 → 非核心线程(按配置策略)
  • 避免瞬时高峰压垮系统。

3. 提供灵活的任务调度策略

  • 支持多种队列(有界/无界、优先级队列)。

  • 支持拒绝策略(当队列满且线程达上限时的处理方式)。

4. 提高系统可管理性

  • 可监控线程状态、活动线程数、完成任务数等。

  • 便于调优和问题诊断。

运行过程

线程池的参数

创建线程池的对象

任务拒绝策略

线程池主要核心原理

①创建一个池子,池子中是空的

②提交任务时,池子会创建新的线程对象,任务执行完毕,线程归还给池子

下回再次提交任务时,不需要创建新的线程,直接复用已有的线程即可

但是如果提交任务时,池子中没有空闲线程,也无法创建新的线程,任务就会排队等待

线程池的大小

线程池的缺点

  • 配置复杂(参数需要根据场景调优)

  • 不当配置可能导致:

    • 队列堆积 → 内存溢出

    • 线程数不足 → 响应慢

    • 线程数过多 → CPU过度切换

相关推荐
炘爚几秒前
C语言(文件操作)
c语言·开发语言
阿蒙Amon4 分钟前
C#常用类库-详解SerialPort
开发语言·c#
盐水冰21 分钟前
【烘焙坊项目】后端搭建(12) - 订单状态定时处理,来单提醒和顾客催单
java·后端·学习
凸头24 分钟前
CompletableFuture 与 Future 对比与实战示例
java·开发语言
wuqingshun31415927 分钟前
线程安全需要保证几个基本特征
java·开发语言·jvm
Moksha26232 分钟前
5G、VoNR基本概念
开发语言·5g·php
努力也学不会java1 小时前
【缓存算法】一篇文章带你彻底搞懂面试高频题LRU/LFU
java·数据结构·人工智能·算法·缓存·面试
攒了一袋星辰1 小时前
高并发强一致性顺序号生成系统 -- SequenceGenerator
java·数据库·mysql
jzlhll1231 小时前
kotlin Flow first() last()总结
开发语言·前端·kotlin
小涛不学习1 小时前
Spring Boot 详解(从入门到原理)
java·spring boot·后端