我爱java系列---【线程池的原理】
一、线程是不是越多越好?
造卡车(线程)要不要时间? 一次性使用,用完了得销毁,销毁要不要耗时间?
➢ 1、线程在java中是一 个对象, 每一个java线程都需要一 个操作系统线程支持。线程创建、销毁需要时间。
如果创建时间+销毁时间>执行任务时间就很不合算。
➢ 2、java对象占用堆内存,操作系统线程占用系统内存,根据jvm规范,一个线程默认最大栈大小1M,这个栈
空间是需要从系统内存中分配的。
线程过多,会消耗很多的内存。
◆造很多的卡车,得需要空间来放它们,会不会造成内存紧张?
➢ 3、操作系统需要频繁切换线程上下文(大家都想被运行),影响性能。
二、如何正确使用多线程?(线程池)
➢ 多线程目的: 充分利用cpu并发做事(多做事)
➢ 线程的本质: 将代码送给cpu执行
➢ 用合适数量的卡车不断运送代码即可。
➢ 这合适数量的线程就构成了一个池。
➢ 如果有任务要执行,就放入池中,池中的一个线程把任务运送到cpu中执行。
三、线程池工作原理
四、手写线程池步骤
1.任务用什么表示?
Runnable:无返回值,只负责执行。
Callable:1.有返回值,返回值用FutureTask对象接收,取的时候直接get;
2.并且可以抛异常。
2.仓库用什么表示?
3.代码示范(待完善)
4.如何确定合适数量的线程?
遇到这个问题,不要急于回答,先反问:你的服务器的最大大小是多少?
参考:
愿你走出半生,归来仍是少年!
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
· DeepSeek 开源周回顾「GitHub 热点速览」
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· AI与.NET技术实操系列(二):开始使用ML.NET
· 单线程的Redis速度为什么快?