线程是不是越多越好?
1.线程在java中是一个对象,更是操作系统的资源,线程创建,销毁需要时间,如果创建时间+销毁时间>执行任务的时间,则不合算。
2.java对象占用堆内存,操作系统线程占用系统内存,根据jvm规范,一个线程默认最大栈大小为1M,这个栈空间需要从系统内存中分配,线程过多,会消耗更多的内存。
3.操作系统需要频繁切换线程上下文(大家都想被执行),影响性能。
线程池管理器:用于创建和管理线程池,包括创建线程池,消耗线程池,添加新任务。
工作线程:线程池中的线程,在没有任务执行时处于等待的状态,可以循环的执行任务。
任务接口:每个任务必须实现的接口,以供工作线程调度任务的执行,它主要规定了任务的入口,任务执行完的收尾工作,任务的执行状态等;
任务队列:用于存放没有处理的任务。提供一种缓冲机制。
线程池API.接口定义和实现类
任务execute过程
1.是否达到线程池核心线程数量?没达到,则创建一个工作线程来执行任务。
2.工作队列是否已满?没满,则将新提交的任务存储在工作队列中。
3.是否达到线程池最大数量?没达到,则创建新的工作线程来执行任务。
4.最后,执行拒绝策略来处理这个任务。