网易云课堂学习-线程池应用及实现原理解析

为什么要使用线程?
线程是不是越多越好?

  1. 线程在java中是一个对象,更是操作系统的资源,线程创建和销毁需要时间。如果创建时间+销毁时间 > 任务执行时间就很不划算。
  2. java对象占用堆内存,操作系统占用系统内存,根据jvm规范,一个线程默认最大栈为1M,这个栈空间需要从系统内存中分配。线程过多,就消耗很多内存。
  3. 操作系统需要频繁切换上下文,影响性能。

线程池的推出,就是为了方便控制线程数量。
线程池原理-概念

  1. 线程池管理器:用于创建并管理线程池,包括创建线程池,销毁线程池,添加新任务。
  2. 工作线程:线程池中的线程,在没有任务时处于等待状态,可以循环执行任务。
  3. 任务接口:每个任务必须实现的接口,以供工作线程调度任务的执行,它主要规定了任务的入口,任务执行后的收尾工作,任务的执行状态等。
  4. 任务队列:用于存放没有处理的任务。提供一种缓冲机制。

线程池API-接口

在这里插入图片描述
在这里插入图片描述
ScheduledExecutorService
在这里插入图片描述
线程池API-Executors工具类
在这里插入图片描述
线程池执行原理-任务execute过程

  1. 是否达到核心线程数量?没达到,创建一个工作线程来来执行任务。
  2. 工作队列是否已满?没满,则将新提交的任务存储在工作队列中。
  3. 是否达到线程的最大数量?没达到,则创建一个新的工作线程来执行任务。
  4. 最后,执行拒绝策略来处理这个任务。
    在这里插入图片描述
    线程数量:
    如何确定合适的线程数量
    计算型任务:cpu数量的1-2倍
    IO型任务:相对比与计算型任务,需要多一些线程,要根据具体的IO阻塞时长考量决定。如tomcat中默认最大线程数量为:200。也可根据需要,在一个最小数量和最大数量间自动增减线程数。
    cpu利用率在80%~90%之间利用的比较充分
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值