版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/u011676300/article/details/83045405
线程池原理–总索引
执行器Executor
- 线程池原理–执行器Executor
- 线程池原理–执行器ExecutorService
- 线程池原理–执行器AbstractExecutorService
- 线程池原理–执行器ThreadPoolExecutor
- 线程池原理–工厂类Executors
拒绝策略
任务队列BlockingQueue
在不使用线程池的时候,我们都是手动创建一个线程并启动。
public MyThread extends Thread{
public void run(){
//do something
.....
}
public static void main(String[] args){
MyThread thread = new MyThread();
thread.start();
}
}
因为创建线程和销毁线程会消耗系统的资源,并不是一种很好的方式去实现多线程,使用线程池比较好。
package com.jt.thread.demo05;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
class MyRunnable implements Runnable {
@Override
public void run() {
for (int x = 0; x < 100; x++) {
System.out.println(Thread.currentThread().getName() + ":" + x);
}
}
}
public class ExecutorServiceDemo {
public static void main(String[] args) {
// 创建一个线程池对象,控制要创建几个线程对象。
// public static ExecutorService newFixedThreadPool(int nThreads)
ExecutorService pool = Executors.newFixedThreadPool(2);
// 可以执行Runnable对象或者Callable对象代表的线程
pool.submit(new MyRunnable());
pool.submit(new MyRunnable());
//结束线程池
pool.shutdown();
}
}
使用线程池的好处:
-
第一:降低资源消耗。通过重复利用已创建的线程降低线程创建和销毁造成的消耗。
-
第二:提高响应速度。当任务到达时,任务可以不需要等到线程创建就能立即执行。
-
第三:提高线程的可管理性。线程是稀缺资源,如果无限制的创建,不仅会消耗系统资源,还会降低系统的稳定性,使用线程池可以进行统一的分配,调优和监控。**