为什么要使用线程?
线程是不是越多越好?
- 线程在java中是一个对象,更是操作系统的资源,线程创建和销毁需要时间。如果创建时间+销毁时间 > 任务执行时间就很不划算。
- java对象占用堆内存,操作系统占用系统内存,根据jvm规范,一个线程默认最大栈为1M,这个栈空间需要从系统内存中分配。线程过多,就消耗很多内存。
- 操作系统需要频繁切换上下文,影响性能。
线程池的推出,就是为了方便控制线程数量。
线程池原理-概念
- 线程池管理器:用于创建并管理线程池,包括创建线程池,销毁线程池,添加新任务。
- 工作线程:线程池中的线程,在没有任务时处于等待状态,可以循环执行任务。
- 任务接口:每个任务必须实现的接口,以供工作线程调度任务的执行,它主要规定了任务的入口,任务执行后的收尾工作,任务的执行状态等。
- 任务队列:用于存放没有处理的任务。提供一种缓冲机制。
线程池API-接口
ScheduledExecutorService
线程池API-Executors工具类
线程池执行原理-任务execute过程
- 是否达到核心线程数量?没达到,创建一个工作线程来来执行任务。
- 工作队列是否已满?没满,则将新提交的任务存储在工作队列中。
- 是否达到线程的最大数量?没达到,则创建一个新的工作线程来执行任务。
- 最后,执行拒绝策略来处理这个任务。
线程数量:
如何确定合适的线程数量
计算型任务:cpu数量的1-2倍
IO型任务:相对比与计算型任务,需要多一些线程,要根据具体的IO阻塞时长考量决定。如tomcat中默认最大线程数量为:200。也可根据需要,在一个最小数量和最大数量间自动增减线程数。
cpu利用率在80%~90%之间利用的比较充分