java重点学习-线程池

十 线程池

10.1 说一下线程池的核心参数,线程池的执行原理

为什么使用线程池

  • 创建线程占用内存空间,每次创建的话会浪费内存
  • cpu有限,大量线程会导致cpu切换

10.2 线程池中有哪些常见的阻塞队列

workQueue-当没有空闲核心线程时,新来任务会加入到此队列排队,队列满会创建救急线程执行任务

  • 1.ArrayBlockingQueue:基于数组结构的有界阻塞队列,FIFO。优先使用初始化设置值
  • 2.LinkedBlockingQueue:基于链表结构的有界阻塞队列,FIFO。
  • 3.DelayedWorkQueue:是一个优先级队列,它可以保证每次出队的任务都是当前队列中执行时间最靠前的
  • 4.SynchronousQueue:不存储元素的阻塞队列,每个插入操作都必须等待一个移出操作。

ArrayBlockingQueue<Runnable> queue = new ArrayBlockingQueue<>( capacity: 2);

LinkedBlockingQueue linkedBlockingQueue = new LinkedBlockingQueue(),

10.3 如何确定核心线程数

  • 高并发、任务执行时间短 >(CPU核数+1),减少线程上下文的切换
  • 并发不高、任务执行时间长
    • I0密集型的任务 >(CPU核数*2+1)
    • 计算密集型任务 →(CPU核数+1)
  • 并发高、业务执行时间长,解决这种类型任务的关键不在于线程池而在于整体架构的设计,看看这些业务里面某些数据是否能做缓存是第一步,增加服务器是第二步,至于线程池的设置,设置参考(2)

10.4 线程池的种类有哪些

  • newFixedThreadPool:创建一个定长线程池,可控制线程最大并发数,超出的线程会在队列中等待
  • newsingleThreadExecutor:创建一个单线程化的线程池,它只会用唯一的工作线程来执行任务,保证所有任务按照指定顺序(FIFO)执行
  • newCachedThreadPool:创建一个可缓存线程池,如果线程池长度超过处理需要,可灵活回收空闲线程,若无可回收,则新建线程
  • newScheduledThreadPool:可以执行延迟任务的线程池,支持定时及周期性任务执行

10.5 为什么不建议用Executors创建线程池

10.6 线程池的使用场景

你们项目哪里用到了多线程

  • 批量导入:使用了线程池+CountDownLatch批量把数据库中的数据导入到了ES(任意)中,避免OOM
  • 数据汇总:调用多个接口来汇总数据,如果所有接口(或部分接口)的没有依赖关系,就可以使用线程池+future来提升性能
  • 异步线程(线程池):为了避免下一级方法影响上一级方法(性能考虑),可使用异步线程调用下一个方法(不需要下一级方法返回值),可以提升方法响应时间
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值