12、线程池

本文深入解析线程池的工作原理,通过生动的银行案例解释为何使用线程池,以及如何利用Java的Executor框架和ThreadPoolExecutor类实现线程池,提升系统性能。

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

1、什么是线程池

在很久很久以前有一家银行,一年之中只有一个客户来办理业务,随着时间的推移,办理业务的人数每年都增加五千。20年之后这家银行办理业务的人次已经到十万。最开始只有一个客户的时候银行只需要雇佣一个按办理业务次数计工资的临时工就行了,办完业务就解雇。随着办理业务的人不断增多,银行老板发现继续雇佣按次计费的员工太麻烦了,每天都在招人,又每天都解雇人。所以老板就想出了一个办法,雇佣几个员工一直在办事大厅待命,有顾客来的时候,柜员就给顾客办业务,办完一个之后再继续为下一个顾客办业务,如果没有下一个顾客就继续待命。就这样这个“聪明”的老板发明了“柜员池”。
线程池就是提前创建若干个线程,如果有任务需要处理,线程池里的线程就会处理任务,处理完之后线程并不会被销毁,而是等待下一个任务。由于创建和销毁线程都是消耗系统资源的,所以当你想要频繁的创建和销毁线程的时候就可以考虑使用线程池来提升系统的性能。

2、如何使用线程池(1)ThreadPoolExecutor

  1. ThreadPoolExecutor
    在这里插入图片描述
    在这里插入图片描述

  2. 线程池的状态
    在这里插入图片描述

  3. 常用方法
    在这里插入图片描述
    在这里插入图片描述

3、如何使用线程池(2)Executor框架接口

  1. 创建线程池的方法:
    在这里插入图片描述
package com.mmall.concurrency.example.threadPool;

import lombok.extern.slf4j.Slf4j;

import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;

@Slf4j
public class ThreadPoolExample1 {

	public static void main(String[] args) {

		ExecutorService executorService = Executors.newCachedThreadPool();

		for (int i = 0; i < 10; i++) {
			final int index = i;
			executorService.execute(new Runnable() {
				@Override
				public void run() {
					System.out.println("task:{}" + index);
				}
			});
		}
		executorService.shutdown();
	}
}

4、为什么要使用线程池

  1. 使用new Thread的方式创建线程,每次都要新建对象,性能差。线程缺乏统一管理,可能无限制的新建线程,互相竞争,有的可能占用过多系统资源导致死机或OOM。所以不建议使用new Thread
  2. 使用线程池的好处:重用存在的线程,减少对象创建、消亡的开销,性能好。可有效控制最大并发线程数,提高系统资源利用率,同时可以避免过多资源竞争,避免阻塞。提供定时执行、定期执行等其他功能
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值