一、认识线程池
整张图图:
二、实现线程池
常用API:
ExecutorService常用方法:
创建线程池的方式1:使用ThreadPoolExecutor
1)ThreadPoolExecutor构造方法:
2)补充:
3)具体实现步骤:
处理Runnable任务:
① 创建线程池对象:
② 创建任务类实例对象,假设这里已经有一个任务类MyRunnable了:
线程池对象通过调用execute()方法把任务发给线程池,然后线程池就会根据我们的设置(核心线程数、临时线程数、任务队列大小等等)去对线程任务进行处理了:
③ 关闭线程池(仅做了解,一般不会使用):
补充:
新任务拒绝策略:
总结(处理Runnable任务):
处理Callable任务:
① 创建线程池对象。
② 线程池对象调用submit()方法来接收线程任务:
③ 这个Future类型其实就是FutureTask的一种多态形式,通过调用Future的get()方法可以获得线程任务执行完之后的返回值。
总结(处理Callable任务):
创建线程池的方式2:使用Executors工具类(了解即可)
Executors底层是基于ThreadPoolExecutor的。
常用API:
总结:
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)