`
shifulong
  • 浏览: 56529 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

Runnable Callable Future FutrueTask ExecutorService的关系

    博客分类:
  • java
阅读更多

 

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]

 

 

分享到:
评论

相关推荐

    java8源码-concurrency:java并发总结

    Runnable Callable Future ExecutorService Class Thread FutureTask FutureTask 获取线程执行结果的原理:以 ThreadPoolExecutor 为例(实现 ExecutorService 接口), 其 submit() 方法提交任务, 返回 一个 ...

    java多线程Future和Callable类示例分享

    JAVA多线程实现方式主要有三种:继承Thread类、实现Runnable接口、使用ExecutorService、Callable、Future实现有返回结果的多线程。其中前两种方式线程执行完后都没有返回值,只有最后一种是带返回值的。今天我们...

    详细解读JAVA多线程实现的三种方式

    本篇文章主要介绍了详细解读JAVA多线程实现的三种方式,主要包括继承Thread类、实现Runnable接口、使用ExecutorService、Callable、Future实现有返回结果的多线程。有需要的可以了解一下。

    线程超时死掉

    不直接构造Future对象,也可以使用ExecutorService.submit方法来获得Future对象,submit方法即支持以 Callable接口类型,也支持Runnable接口作为参数,具有很大的灵活性。使用示例如FutureTaskAndExcutor中的limit...

    Java 实现多线程的几种方式汇总

    JAVA多线程实现方式主要有三种:继承Thread类、实现Runnable接口、使用ExecutorService、Callable、Future实现有返回结果的多线程。其中前两种方式线程执行完后都没有返回值,只有最后一种是带返回值的。

    【多线程高并发编程】三 Callable源码分析

    文章目录前言1.Callable的前世今生1.1 Callable的前世Runnable测试结果1.2 Callable的今生通过FutureTask+Thread调用ExecutorService+Future调用实现2.源码分析2.1 第一步,实现Callable接口2.2 FutureTask类结构图...

    线程池ThreadPoolExecutor

    引子 线程的创建和销毁比较消耗资源,... Future submit(Callable task):执行任务,有返回值,一般又来执行Callable void shutdown() :关闭线程池 AbstractExecutorService:基本实现了ExecutorService的所有方法 Th

    线程池之Executor框架.docx

    包括被执行任务需要实现的接口:Runnable接口或者Callable接口。 任务的执行 。包括任务执行机制的核心接口Executor,以及继承自Executor的ExecutorService接口。Executor框架有两个关键类实现了ExecutorService...

    \java超强笔记(超级经典)

    Callable是类似于Runnable的接口,实现Callable接口的类和实现Runnable的类都是可被其它线程执行的任务。Callable和Runnable有几点不同: Callable规定的方法是call(),而Runnable规定的方法是run(). ...

    一篇文章认识4种Java多线程的创建方式

    并行与并发:那么JAVA多线程实现方式:(1)继承Thread类实现多线程:(2)实现Runnable接口方式实现多线程:(3)实现callable方式:(比实现Runnable方式强大)(4)使用ExecutorService、Future(线程池):实现有返回...

    汪文君高并发编程实战视频资源全集

    ├─第一阶段 │ 源码+ppt.rar ...ExecutorService讲解_.mp4  高并发编程第三阶段39讲 ThreadPoolExecutor七大构造参数详细讲解_.mp4  高并发编程第三阶段40讲 ThreadPoolExecutor关闭(很重要)精讲...

    汪文君高并发编程实战视频资源下载.txt

    ├─第一阶段 │ 源码+ppt.rar ...ExecutorService讲解_.mp4  高并发编程第三阶段39讲 ThreadPoolExecutor七大构造参数详细讲解_.mp4  高并发编程第三阶段40讲 ThreadPoolExecutor关闭(很重要)精讲...

    java核心知识点整理.pdf

    1. 目录 1. 2. 目录 .........................................................................................................................................................1 JVM .........................

    JAVA核心知识点整理(有效)

    1. 目录 1. 2. 目录 .........................................................................................................................................................1 JVM ........................

Global site tag (gtag.js) - Google Analytics