21.0、Java多线程——线程池
使用线程池:
背景:经常创建和销毁、使用量特别大的资源,比如并发情况下的线程,对性能影响很大
思路:提前创建好 多个线程,放入线程池中,使用时直接获取,使用完放回池中。可以避免频繁的创建、销毁,实现重复利用,类似生活中的公共交通工具
好处:
1、提高响应速度(减少了创建新线程的时间)
2、降低资源消耗(重复利用线程池中线程,不需要每次都创建)
3、便于线程管理(......)
corePoolSize:核心池的大小
maximumPoolSize:最大线程数
keepAliveTime:线程没有任务时最多保持多长时间后会终止
JDK 5.0 起提供了线程池相关 API :ExecutorService 、 Executors
先来看看ExecutorService:
真正的线程池接口,常见子类ThreadPoolExecutor
1、void execute(Runnable command) :执行任务/命令,没有返回值,一般用来执行Runnable
2、<T> Future <T> submit(Callable<T> task) :执行任务,有返回值,一般用来执行 Callable
3、void shutdown() :关闭线程
再来看看Executors :
工具类、线程池的工具类,用于创建并返回不同类型的线程池
用代码来测试一下线程池,如下所示:
TestPool.java文件:
package com.hkl.threadCall;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
//测试线程池
public class TestPool {
public static void main(String[] args) {
// 创建服务,创建线程池
// newFixedThreadPool 参数为:线程池大小
ExecutorService service = Executors.newFixedThreadPool(10);
// 执行
service.execute(new MyThread());
service.execute(new MyThread());
service.execute(new MyThread());
service.execute(new MyThread());
// 关闭连接
service.shutdown();
}
}
class MyThread implements Runnable {
@Override
public void run() {
System.out.println(Thread.currentThread().getName());
}
}
首先用ExecutorService 创建服务和线程池
ExecutorService service = Executors.newFixedThreadPool(10);
然后用 service 执行 execut() 方法 开启线程
service.execute(new MyThread());
记得在最后要用 shutdown()方法 关闭连接
service.shutdown();
运行截图,如下所示:

线程池 成功创建 线程 并 开启~~~
本文介绍了Java中线程池的概念和使用,强调了线程池能提高响应速度、降低资源消耗和便于线程管理的优势。通过ExecutorService和Executors工具类创建线程池,并展示了如何使用execute和shutdown方法执行和关闭线程。示例代码展示了如何创建固定大小的线程池并执行任务。
752

被折叠的 条评论
为什么被折叠?



