java多线程总结

来源:互联网 发布:如何自已推广淘宝店铺 编辑:程序博客网 时间:2024/06/08 10:17

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()


原创粉丝点击