ThreadPool线程池原理

本文介绍了Java中线程池的运行原理,包括线程的抢占式调度、独立的栈空间以及主线程等待子线程执行完毕的机制。线程池限制了系统中线程数量,降低了资源消耗,提高了响应速度和线程管理效率,详细讨论了其在并发执行中的作用和重要参数。

线程池运行原理

Java中线程池运行原理:
            1.线程的调度是抢占式
            2.线程启动之后会开辟独立的栈空间(工作内存),来执行线程的任务
            3.主线程会等所有的子线程执行完毕,才会销毁,才会结束程序运行

Java程序:(只有一个进程)
                1.一个Java程序就是只有一个进程,而一个进程一次只能执行一条线程
                2.所以Java只有多线程并发(交替执行),    没有多线程并行

进程和线程

进程:在操作系统中能够独立运行,并且作为资源分配的基本单位,是应用程序的可执行单元(*.exe文件)   。一个应用程序可以有多个进程,每个进程都有独立的运行内存空间。系统运行一个应用程序就是一个进程从创建、运行到消亡的过程。

线程:是一个比进程更小的执行单位,是进程的可执行单元,  也被称为轻量级进程。

一个进程可以有多个线程,每个线程都有独立的运行内存空间

并行和并发

并行:指两个或多个事件在**同一时刻**发生(同时执行)。


并发:指两个或多个事件在**同一个时间段内**发生(交替执行)。

线程池Thread Pool

线程池做的工作主要是控制运行的线程的数量,处理过程中将任务放入队列,然后在线程创建后 启动这些任务,如果线程数量超过了最大数量超出数量的线程排队等候,等其它线程执行完毕, 再从队列中取出任务来执行。
他的主要特点为:线程复用;控制最大并发数;管理线程
一般的线程池主要分为以下 4 个组成部分:
        1. 线程池管理器:用于创建并管理线程池
        2. 工作线程:线程池中的线程
        3. 任务接口:每个任务必须实现的接口,用于工作线程调度其运行
        4. 任务队列:用于存放待处理的任务,提供一种缓冲机制

线程池作用:限制系统中执行线程的数量

  1. 降低资源消耗。减少了创建和销毁线程的次数,每个工作线程都可以被重复利用,可执行多个任务。

  2. 提高响应速度。当任务到达时,任务可以不需要的等到线程创建就能立即执行。

  3. 提高线程的可管理性。可以根据系统的承受能力,调整线程池中工作线线程的数目,防止因为消耗过多的内存,而把服务器累趴下(每个线程需要大约1MB内存,线程开的越多,消耗的内存也就越大,最后死机)。 

线程池参数

1. corePoolSize:指定线程池中的核心线程数量。线程池的基本大小
2. maximumPoolSize:指定了线程池中的最大线程数量。最大线程数
3. keepAliveTime:当前线程池数量超过 corePoolSize 时,多余的空闲线程的存活时间,即多次时间内会被销毁。线程的存活时间
4. unit:keepAliveTime 的单位。
5. workQueue:任务队列,被提交但尚未被执行的任务。(用于保存等待执行任务的阻塞队列,提交的任务将会被放到这个队列里。)
6. threadFactory:线程工厂,用来创建线程,一般用默认的即可。
7. handler:拒绝策略 ,当任务太多来不及处理,如何拒绝任务。

线程池的启动策略----线程池原理

1. 线程池刚创建时,里面没有一个线程。任务队列是作为参数传进来的。不过,就算队列里面有任务,线程池也不会马上执行它们。
2. 当调用 execute() 方法添加一个任务时,线程池会做如下判断:
        a) 如果正在运行的线程数量小于 corePoolSize,那么马上创建线程运行这个任务;
        b) 如果正在运行的线程数量大于或等于 corePoolSize,那么将这个任务放入队列;
        c) 如果这时候队列满了,而且正在运行的线程数量小于 maximumPoolSize,那么还是要创建非核心线程立刻运行这个任务;
        d) 如果队列满了,而且正在运行的线程数量大于或等于 maximumPoolSize,那么线程池会抛出异常 RejectExecutionException。
3. 当一个线程完成任务时,它会从队列中取下一个任务来执行。
4. 当一个线程无事可做,超过一定的时间(keepAliveTime)时,线程池会判断,如果当前运行的线程数大于 corePoolSize,那么这个线程就被停掉。所以线程池的所有任务完成后,它最终会收缩到 corePoolSize 的大小。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值