使用线程池的背景:
线程的经常创建和销毁、使用量特别大的资源,比如并发情况下的线程,对性能影响很大。
使用线程池的思路:
提前创建好多个线程,放入线程池中,使用时直接获取,使用完放回线程池中。避免频繁创建销毁,实现重复利用。类似生活中的公共交通工具。
优点:
- 提高响应速度。
- 降低资源消耗。
- 便于线程管理。
ExecutorService和Executors
ExecutorService:真正的线程池接口。常见子类ThreadPoolExecutor。
Executors:工具类、线程池的工厂类,用于创建并返回不同类型的线程池。
线程池使用实例:
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
public class ThreadPoolTest {
public static void main(String[] args) {
//创建服务,创建资源池
ExecutorService esr = Executors.newFixedThreadPool(5);
//执行
esr.execute(new ThreadPool());
esr.execute(new ThreadPool());
esr.execute(new ThreadPool());
esr.execute(new ThreadPool1());
esr.execute(new ThreadPool());
esr.execute(new ThreadPool1());
esr.execute(new ThreadPool());
esr.execute(new ThreadPool());
//关闭服务
esr.shutdown();
}
}
class ThreadPool implements Runnable{
@Override
public void run() {
System.out.println(Thread.currentThread().getName()+"开心吗");
}
}
class ThreadPool1 implements Runnable{
@Override
public void run() {
System.out.println(Thread.currentThread().getName()+"不开心");
}
}