1. 实现线程有三种方法
继承Thread、实现Runnable、实现Callable,其中前两种没有返回值,最后一种有返回值(返回值为Future类型)。
2. 启动或执行线程有两种方法
(1) thread.start()
(a) 继承Thread,直接thread.start()
(b) 实现Runnable,先new Thread(Runnable),然后thread.start()
(c) 实现Callable,先new FutureTask(Callable),然后new Thread(Runnable),最后thread.start()
(2) ExecutorService.submit()
(a) 实现Callable有返回值,调用<T> Future<T> submit(Callable<T> task);
(b) 实现Runnable无返回值,调用Future<?> submit(Runnable task);
(c) 实现Runnable,如果也想要有返回值,调用<T> Future<T> submit(Runnable task, T result);
3. Runnable和Callable的相互转化
Runnable --> Callable(无返回值转有返回值): Executors.callable(Runnable); 或 Executors.callable(Runnable, T);
Callable--> Runnable (有返回值转无返回值): new FutureTask(Callable); (FutureTask实现了Runnable接口)
4. 返回值为Future类型有两个作用
(1) 返回线程执行结果:future.get(); 或 future.get(long timeout, TimeUnit unit);
(2) 操作线程状态:
(a) 判断线程是否已完成:future.isDone();
(b) 取消线程:future.cancel(true);
(c) 判断线程是否已取消:future.isCancelled();
所以,Runnable 也可以像Callable一样返回Future,Runnable返回的Future虽然没有返回值,但是仍然可以用来操作线程状态。
5. Executor、ExecutorService、AbstractExecutorService、ThreadPoolExecutor、Executors之间的关系
(1) Executor是线程调度的最高接口,ThreadPoolExecutor是最核心的最终实现,关系是:Executor --> ExecutorService --> AbstractExecutorService --> ThreadPoolExecutor
(2) Executors是一个线程调度工具类,包含了一些静态工具方法
6. Executors相关方法介绍
(1) 线程池工厂
(a) 单任务线程池,newSingleThreadExecutor()
(b) 固定大小的线程池,newFixedThreadPool(int)
(c) 带缓存的线程池,newCachedThreadPool() //如果submit的是新任务,就创建新线程;如果是原来submit过的任务,则还使用原来的线程
(d) 带延迟的连接池,newScheduledThreadPool() //可以为提交的任务,设置延迟一段时间执行
(e) 单任务带延迟的连接池,newSingleThreadScheduledExecutor()