Java 线程池(threads pool), Executor 的使用

为什么要线程池?创建线程本身是需要时间的,如果作业时间较短或作业请求较平凡,很多时间会浪费在启动和关闭线程上。另外,计算机的性能是有限的,当程序无止境的创建进程时,可能会导致机器过载崩溃(比如服务器为每个用户 创建一个线程, 而过多的用户同时请求访问)。


线程池是以上两种问题很好的解决方案。一方面,线程池避免了反复的创建、销毁线程,浪费时间;另外一方面, 线程池可以避免创建过多的线程,而是让超出承载能力的请求排队。

2>如何实现?

Java 提供了线程池的管理类Executor, 可以用来实现常用的多数线程池。同时,你也可以按照自己需求,自己编写自己的线程池。


Executor/Executor Service

 a) 初始化一个pool

ExecutorService pool =Executor.newCachedThreadPool(); //1

ExecutorService pool =Executor.newFixedThreadPool(5);//2

ExecutorService pool =Executor.newSingleThreadPool();//3

(ExecutorService 是Executor的子类,从Executor继承了execute(Runnable r) 的方法 )

CachedThreadPool: 是指带缓冲的线程池机制。线程池本身为空,当有作业时便会开启新的线程。这个线程池的特点是,当作业结束后,线程池并不会立即销毁,而会延迟某个时间再销毁。这样,当延迟时间内有新的作业进入时,就省去了开启新的线程池的时间。

FixedThreadPool: 是指指定线程池指定线程数量。无论有没有没作业,线程池都回保有这么多线程,当作业来的时候,就会放到这些线程上。当作业数量超过了线程数,作业就必须排队等待。

SingleThreadPool: 就是FixedThreadPool(1) 的情况,完全一样。


b)执行作业

通过 exexute (Runnable r)的方法来执行新的作业。比如:

pool.execute(new mRunnable);

c)执行带返回结果的作业

ExecutorService 提供了带返回结果的作业执行方法,包括:

public abstract Future<T> submit (Callable<T> task)

Runnable 包装了一个作业,但并不带返回值,Callable则允许你定义返回值。如你可以这样定义一个实现Callable接口:
import java.util.concurrent.*;
import java.util.*;
class TaskWithResult implements Callable<String> {
private int id;
public TaskWithResult(int id) {
this.id = id;
}
public String call() {
return "result of TaskWithResult " + id;
}
}
public class CallableDemo {
public static void main(String[] args) {
ExecutorService exec = Executors.newCachedThreadPool();
ArrayList<Future<String>> results =
new ArrayList<Future<String>>();
for(int i = 0; i < 10; i++)
results.add(exec.submit(new TaskWithResult(i)));
for(Future<String> fs : results)
try {
// get() blocks until completion:
System.out.println(fs.get());
} catch(InterruptedException e) {
System.out.println(e);
return;
} catch(ExecutionException e) {
System.out.println(e);
} finally {
exec.shutdown();
}
}
} /* Output:
result of TaskWithResult 0
result of TaskWithResult 1
result of TaskWithResult 2
result of TaskWithResult 3
result of TaskWithResult 4
result of TaskWithResult 5
result of TaskWithResult 6
result of TaskWithResult 7
result of TaskWithResult 8
result of TaskWithResult 9
*///:~

e) shutdown();
通过这个方法关闭线程池。










 



  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值