public interface ExecutorService extends Executor {...}
ExecutorService#submit有三个重载方法,之前一直没注意,今天仔细以研究,还是有好些知识点的
1.第一个就不说了
<T> Future<T> submit(Callable<T> task);
2.返回的future#get会阻塞,得到的结果就是result
<T> Future<T> submit(Runnable task, T result);
3.future#get也是会阻塞的,只是返回的结果是null
Future<?> submit(Runnable task);
a.FutureTask是Future的唯一实现
public class FutureTask<V> implements RunnableFuture<V> {...}
public interface RunnableFuture<V> extends Runnable, Future<V> {...}
code demo
ExecutorService executor = Executors.newSingleThreadExecutor(); Future future = executor.submit(new Runnable() { public void run() { System.out.println("run"); try { Thread.sleep(2000); } catch (InterruptedException e) { e.printStackTrace(); } } }); System.out.println(future.get()); final List<String> list = Lists.newArrayList("a", "b"); Future future2 = executor.submit(new Runnable() { public void run() { list.add("c"); System.out.println("run with result"); try { Thread.sleep(2000); } catch (InterruptedException e) { e.printStackTrace(); } } }, list); System.out.println(future2.get()); executor.shutdown();
执行结果
run null run with result [a, b, c]
相关推荐
Runnable Callable Future ExecutorService Class Thread FutureTask FutureTask 获取线程执行结果的原理:以 ThreadPoolExecutor 为例(实现 ExecutorService 接口), 其 submit() 方法提交任务, 返回 一个 ...
JAVA多线程实现方式主要有三种:继承Thread类、实现Runnable接口、使用ExecutorService、Callable、Future实现有返回结果的多线程。其中前两种方式线程执行完后都没有返回值,只有最后一种是带返回值的。今天我们...
本篇文章主要介绍了详细解读JAVA多线程实现的三种方式,主要包括继承Thread类、实现Runnable接口、使用ExecutorService、Callable、Future实现有返回结果的多线程。有需要的可以了解一下。
不直接构造Future对象,也可以使用ExecutorService.submit方法来获得Future对象,submit方法即支持以 Callable接口类型,也支持Runnable接口作为参数,具有很大的灵活性。使用示例如FutureTaskAndExcutor中的limit...
JAVA多线程实现方式主要有三种:继承Thread类、实现Runnable接口、使用ExecutorService、Callable、Future实现有返回结果的多线程。其中前两种方式线程执行完后都没有返回值,只有最后一种是带返回值的。
文章目录前言1.Callable的前世今生1.1 Callable的前世Runnable测试结果1.2 Callable的今生通过FutureTask+Thread调用ExecutorService+Future调用实现2.源码分析2.1 第一步,实现Callable接口2.2 FutureTask类结构图...
引子 线程的创建和销毁比较消耗资源,... Future submit(Callable task):执行任务,有返回值,一般又来执行Callable void shutdown() :关闭线程池 AbstractExecutorService:基本实现了ExecutorService的所有方法 Th
包括被执行任务需要实现的接口:Runnable接口或者Callable接口。 任务的执行 。包括任务执行机制的核心接口Executor,以及继承自Executor的ExecutorService接口。Executor框架有两个关键类实现了ExecutorService...
Callable是类似于Runnable的接口,实现Callable接口的类和实现Runnable的类都是可被其它线程执行的任务。Callable和Runnable有几点不同: Callable规定的方法是call(),而Runnable规定的方法是run(). ...
并行与并发:那么JAVA多线程实现方式:(1)继承Thread类实现多线程:(2)实现Runnable接口方式实现多线程:(3)实现callable方式:(比实现Runnable方式强大)(4)使用ExecutorService、Future(线程池):实现有返回...
├─第一阶段 │ 源码+ppt.rar ...ExecutorService讲解_.mp4 高并发编程第三阶段39讲 ThreadPoolExecutor七大构造参数详细讲解_.mp4 高并发编程第三阶段40讲 ThreadPoolExecutor关闭(很重要)精讲...
├─第一阶段 │ 源码+ppt.rar ...ExecutorService讲解_.mp4 高并发编程第三阶段39讲 ThreadPoolExecutor七大构造参数详细讲解_.mp4 高并发编程第三阶段40讲 ThreadPoolExecutor关闭(很重要)精讲...
1. 目录 1. 2. 目录 .........................................................................................................................................................1 JVM .........................
1. 目录 1. 2. 目录 .........................................................................................................................................................1 JVM ........................