线程池
线程池的概念
在java中,我们可以利用多线程来最大化的使用CPU多和计算能力,但是线程也是一把双刃剑。
线程池本质是一种对象池,用于管理线程资源,在执行任务前,需要从线程池中拿出线程,任务执行完成后,将线程放回线程池,听过这种反复利用机制,可以有效的避免直接创建线程带来的危险。
优点:1、降低资源消耗 2、提高任务执行相应速度 3、提高线程可管理性。
缺点:频繁的创建线程会占用CPU内存、线程太多,线程切换带来的开锁不可忽视、线程太少CPU达不到牌
创建线程池:Executors:一个线程池工厂,提供了很多线程方法
java.util.concurrent.Executor负责线程的使用和调度的接口,
ExecutorServer 子接口:线程池的主接口
public static void main(String[] args) {
//创建一个线程池,容量为5个线程
ExecutorService executor = Executors.newFixedThreadPool(5);
for (int i = 0; i < 10; i++) {
executor.submit(()->{
System.out.println(“Thread id is:” + Thread.currentThread().getId());
try {
Thread.sleep(1000L);
} catch (InterruptedException e) {
e.printStackTrace();
}
});
}
//线程关闭
executor.shutdown();
}
关闭线程池:shutdown()将线程池状态置为SHUTDOWN,不在接收新的任务,同时等待线程池中已有的任务执行完成在结束。
shutdownNow()将线程池状态置为SHUTDOWN,对所有线程执行interrupt操作。