1、什么是线程池
在很久很久以前有一家银行,一年之中只有一个客户来办理业务,随着时间的推移,办理业务的人数每年都增加五千。20年之后这家银行办理业务的人次已经到十万。最开始只有一个客户的时候银行只需要雇佣一个按办理业务次数计工资的临时工就行了,办完业务就解雇。随着办理业务的人不断增多,银行老板发现继续雇佣按次计费的员工太麻烦了,每天都在招人,又每天都解雇人。所以老板就想出了一个办法,雇佣几个员工一直在办事大厅待命,有顾客来的时候,柜员就给顾客办业务,办完一个之后再继续为下一个顾客办业务,如果没有下一个顾客就继续待命。就这样这个“聪明”的老板发明了“柜员池”。
线程池就是提前创建若干个线程,如果有任务需要处理,线程池里的线程就会处理任务,处理完之后线程并不会被销毁,而是等待下一个任务。由于创建和销毁线程都是消耗系统资源的,所以当你想要频繁的创建和销毁线程的时候就可以考虑使用线程池来提升系统的性能。
2、如何使用线程池(1)ThreadPoolExecutor
-
ThreadPoolExecutor
-
线程池的状态
-
常用方法
3、如何使用线程池(2)Executor框架接口
- 创建线程池的方法:
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、为什么要使用线程池
- 使用new Thread的方式创建线程,每次都要新建对象,性能差。线程缺乏统一管理,可能无限制的新建线程,互相竞争,有的可能占用过多系统资源导致死机或OOM。所以不建议使用new Thread
- 使用线程池的好处:重用存在的线程,减少对象创建、消亡的开销,性能好。可有效控制最大并发线程数,提高系统资源利用率,同时可以避免过多资源竞争,避免阻塞。提供定时执行、定期执行等其他功能