java多线程总结

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


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值