《Java Concurrency in Practice》ch8 Applying Thread Pools

本文深入探讨了线程池的基本概念、如何设置线程池大小及其对内存、文件句柄、socket句柄和数据库连接的影响。重点介绍了Java中的ThreadPoolExecutor类,包括其核心参数配置、按需构造、创建新线程、保持活动时间、排队、被拒绝任务处理及钩子方法的应用。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1. 线程池中,如果任务之间相互依赖,可能导致死锁。

2. 设置线程池的大小

其它可能影响线程池大小的因素:内存、文件句柄、socket句柄、数据库连接等。

3. ThreadPoolExecutor

JDK上这样写,

为了便于跨大量上下文使用,此类提供了很多可调整的参数和扩展钩子 (hook)。但是,强烈建议程序员使用较为方便的 Executors 工厂方法 Executors.newCachedThreadPool()(无界线程池,可以进行自动线程回收)、Executors.newFixedThreadPool(int)(固定大小线程池)和 Executors.newSingleThreadExecutor()(单个后台线程),它们均为大多数使用场景预定义了设置。

以下均可配置:

核心和最大池大小、按需构造、创建新线程、保持活动时间、排队、被拒绝的任务、钩子 (hook) 方法 、队列维护、终止

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值