声明:原创文章,转载请注明出处。http://www.jianshu.com/u/e02df63eaa87
一、线程池的使用
1、单线程线程池
public class SingleThread {
public static void main(String[] args) {
ExecutorServic eexecutor = Executors.newSingleThreadExecutor();
for (inti = 0; i < 5; i++) {
final int no = i;
Runnable runnable = newRunnable() {
public void run() {
System.out.println(no);
}
};
executor.execute(runnable);
}
executor.shutdown();
}
}
2、固定线程数的线程池
public class FixedThreadPool {
public static void main(String[] args) {
ExecutorServiceexecutor = Executors.newFixedThreadPool(5);
for (inti = 0; i < 20; i++) {
finalintno = i;
Runnablerunnable = newRunnable() {
publicvoidrun() {
try {
System.out.println("In:" + no);
Thread.sleep(1000);
System.out.println("Out:" + no);
} catch(Exceptione) {}
}
};
executor.execute(runnable);
}
executor.shutdown();
}
}
3、定时周期执行指定的任务
public class ScheduledThread {
public static void main(String[] args) {
//以固定延迟时间进行执行,本次执行完成后,到达延迟时间才会执行新的任务
ScheduledExecutorServiceexecutor = Executors.newScheduledThreadPool(1);
executor.scheduleWithFixedDelay(newPrintThread(1), // 任务名字
0, // 初始化延时0秒后开始执行
1, // 每隔1秒执行一次
TimeUnit.SECONDS // 时间单位
);
}
}
二、线程池的好处
1、四个好处
(1)降低资源消耗:降低线程的创建和销毁产生的消耗。
(2)提高响应速度:任务达到时,任务可以不需要等到线程创建就能立即执行。
(3)提高线程的可管理性:统一分配,调优和监控。
(4)防止服务器过载,形成内存溢出,或CPU耗尽。
2、线程池技术提高程序的性能
多线程技术主要解决处理器单元内多个线程执行的问题,可以显著减少处理器单元的闲置时间,增加处理器单元的吞吐能力。
3、线程池的应用范围
(1)需要大量的线程来完成任务,且完成任务的时间比较短。
(2)对性能要求苛刻的应用。
(3)接收突发性的大量请求,但不至于使服务器因此产生大量的线程应用。
三、线程池的工作机制和原理
1、线程池核心的两个队列:
- 线程等待池,即线程队列BlockingQueue。
- 任务处理池,即正在工作的Thread列表。
2、线程池的核心参数:
- 核心池的大小,即固定大小。
- 最大处理线程池数,当线程池里面的线程数: 核心池大小 < 线程数 < 最大处理线程池数,会动态创建与回收线程池里面的线程资源(如果当前核心池的线程都在工作,并且还有任务时,会临时增加的线程数
)。
3、线程池任务拒绝策略
(1)AbortPolicy:直接抛出异常。
(2)CallerRunPolicy:只用调用者所在线程来运行任务。
(3)DiscardOldestPolicy:丢弃队列中的最旧的一个任务,并执行当前任务。
(4)DiscardPolicy:不处理,丢弃掉。