13、Executor

###Executor有几大部分组成
1、任务:任务的执行需要实现Runable 接口或Callable接口
2、任务的执行:Executor的子类 ExcutorService更强大。
有两个关键类实现了接口:ThreadPoolExecutor 和ScheduledThreadPoolExecutor;
3、异步计算的结果:包括接口Future 和实现Future接口的FutureTask(实现了RunableFuture,RunableFuture继承了Runable接口和Future接口);

###框架
13、Executor_第1张图片
###应用

Executor.submit() 有返回值的
Executor.execute()没有返回值的

###线程
创建线程的3种方式
1、继承Thread 类,很少用,因为有局限性。
2、实现Runable接口,线程池就是实现runable接口的
3、实现Callable接口,有返回值的。

###固定线程池(FixedThreadPool)
13、Executor_第2张图片

固定线程池的组成:
1、LinkedBlockingQueue(有界阻塞队列)
2、corePool

为什么使用无解队列会使内存崩溃
1、任务进入线程池,会先看coresize(核心线程数)
2、如果核心线程数满了,则会进入队列
3、有界队列里,队列数满了,会看最大线程数是否满了,如果最大线程未满,则直接创建线程
如果最大线程满了,则实行拒绝策略(抛异常,不会排队,不会增加内存)
如果是无解队列,则队列永远都不会满,那么数据量大的情况下,会内存崩溃,影响系统运行

###调度线程池(ScheduledThreadPoolExecutor)
调度线程池的组成:
1、delayQueue 延时队列(无界队列)
2、corePool

你可能感兴趣的:(Java并发编程)