关于java中的线程池
为何使用线程池
并发的线程数量很多,并且每个线程都是执行一个时间很短的任务就结束了,这样频繁创建线程
就会大大降低 系统的效率,因为频繁创建线程和销毁线程需要时间. 线程池就是一个容纳多个线程的容
器,池中的线程可以反复使用,省去了频繁创建线程对象的操作,节省了大量的时间和资源。
Java中的四种线程池 . ExecutorService
1、缓冲线程池
/**
- 缓存线程池.
- (长度无限制)
- 执行流程:
-
- 判断线程池是否存在空闲线程
-
- 存在则使用
-
- 不存在,则创建线程 并放入线程池, 然后使用
*/
ExecutorService service = Executors.newCachedThreadPool();
//向线程池中 加入 新的任务
service.execute(new Runnable() {
@Override
public void run() {
System.out.println(“线程的名称:”+Thread.currentThread().getName());
}
});
service.execute(new Runnable() {
@Override
public void run() {
System.out.println(“线程的名称:”+Thread.currentThread().getName());
}
});
service.execute(new Runnable() {
@Override
public void run() {
System.out.println(“线程的名称:”+Thread.currentThread().getName());
}
});
- 不存在,则创建线程 并放入线程池, 然后使用
2、定长线程池
/**
- 定长线程池.
- (长度是指定的数值)
- 执行流程:
-
- 判断线程池是否存在空闲线程
-
- 存在则使用
-
- 不存在空闲线程,且线程池未满的情况下,则创建线程 并放入线程池, 然后使用
-
- 不存在空闲线程,且线程池已满的情况下,则等待线程池存在空闲线程
*/
ExecutorService service = Executors.newFixedThreadPool(2);
service.execute(new Runnable() {
@Override
public void run() {
System.out.println(“线程的名称:”+Thread.currentThread().getName());
}
});
service.execute(new Runnable() {
@Override
public void run() {
System.out.println(“线程的名称:”+Thread.currentThread().getName());
}
});
- 不存在空闲线程,且线程池已满的情况下,则等待线程池存在空闲线程
3、单线程线程池
效果与定长线程池 创建时传入数值1 效果一致.
/**
- 单线程线程池.
- 执行流程:
-
- 判断线程池 的那个线程 是否空闲
-
- 空闲则使用
-
- 不空闲,则等待 池中的单个线程空闲后 使用
*/
ExecutorService service = Executors.newSingleThreadExecutor();
service.execute(new Runnable() {
@Override
public void run() {
System.out.println(“线程的名称:”+Thread.currentThread().getName());
}
});
service.execute(new Runnable() {
@Override
public void run() {
System.out.println(“线程的名称:”+Thread.currentThread().getName());
}
});
- 不空闲,则等待 池中的单个线程空闲后 使用
4、周期性任务定长线程池
-
- 判断线程池是否存在空闲线程
-
- 存在则使用
-
- 不存在空闲线程,且线程池未满的情况下,则创建线程 并放入线程池, 然后使用
-
- 不存在空闲线程,且线程池已满的情况下,则等待线程池存在空闲线程
*/
ExecutorService service = Executors.newFixedThreadPool(2);
service.execute(new Runnable() {
@Override
public void run() {
System.out.println(“线程的名称:”+Thread.currentThread().getName());
}
});
service.execute(new Runnable() {
@Override
public void run() {
System.out.println(“线程的名称:”+Thread.currentThread().getName());
}
});
- 不存在空闲线程,且线程池已满的情况下,则等待线程池存在空闲线程