多线程与高并发(八)

多线程与高并发(八)

ThreadPool

目前提供两种类型的线程池,一种是普通的类型ThreadPoolExecutor,第二种就是ForkJoinPool。这两种是不同类型的线程池。

在阿里JAVA开发手册中有说明到:线程资源必须通过线程池提供,不允许在应用中自行显式创建线程。

说明:线程池的好处是减少在创建和销毁线程上所消耗的时间以及系统资源的开销,解决资源不足的问题。如果不使用线程池,有可能造成系统创建大量同类线程而导致消耗完内存或者“过度切换”的问题。

线程池不允许使用Executors去创建,而是通过ThreadPoolExecutor的方式,这样的处理方式是为了规避资源耗尽的风险。

ThreadPoolExecutor

ThreadPool维护着两个集合,第一个是线程的集合,第二个是任务的集合。

线程池有7大参数:
在这里插入图片描述

ForkJoinPool

  • 分解汇总的任务
  • 用很少的线程可以执行很多的任务(子任务)TPE做不到先执行子任务
  • CPU密集型
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

༄༊心灵骇客༣

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值