线程池

    xiaoxiao2022-07-06  211

    线程是不是越多越好?

    1.线程在java中是一个对象,更是操作系统的资源,线程创建,销毁需要时间,如果创建时间+销毁时间>执行任务的时间,则不合算。

    2.java对象占用堆内存,操作系统线程占用系统内存,根据jvm规范,一个线程默认最大栈大小为1M,这个栈空间需要从系统内存中分配,线程过多,会消耗更多的内存。

    3.操作系统需要频繁切换线程上下文(大家都想被执行),影响性能。

    线程池管理器:用于创建和管理线程池,包括创建线程池,消耗线程池,添加新任务。

    工作线程:线程池中的线程,在没有任务执行时处于等待的状态,可以循环的执行任务。

    任务接口:每个任务必须实现的接口,以供工作线程调度任务的执行,它主要规定了任务的入口,任务执行完的收尾工作,任务的执行状态等;

    任务队列:用于存放没有处理的任务。提供一种缓冲机制。

    线程池API.接口定义和实现类

    任务execute过程

    1.是否达到线程池核心线程数量?没达到,则创建一个工作线程来执行任务。

    2.工作队列是否已满?没满,则将新提交的任务存储在工作队列中。

    3.是否达到线程池最大数量?没达到,则创建新的工作线程来执行任务。

    4.最后,执行拒绝策略来处理这个任务。

    最新回复(0)