文档章节

Callable 执行器

噼里啪啦嘣
 噼里啪啦嘣
发布于 2016/05/08 20:31
字数 202
阅读 5
收藏 0
import java.util.concurrent.*;

/**
 * Created by zyBourn on 15/12/25.
 */
public class Entity {
    /**
     * 执行器
     * 用于启动并控制线程的执行
     * 核心接口为Executor,包含一个execute(Runnable)用于指定被执行的线程
     * ExecutorService接口用于控制线程执行和管理线程
     * 预定义了如下执行器:
     * ThreadPoolExecutor/ScheduledThreadPoolExecutor/ForkJoinPool
     *
     * Callable 与 Future
     *
     * Callable<V>:标识具有返回值的线程
     * V:标识返回值类型
     * call():执行任务
     * Future<V>:表示Callable的返回值
     * V:返回值类型
     * get():获取返回值
     */

    public static void main(String[] args) throws Exception{
        ExecutorService ex= Executors.newFixedThreadPool(2);

        Future<Integer> r1=ex.submit(new Mc(1, 100));
        Future<Integer> r2=ex.submit(new Mc(100,10000));
        System.out.println(r1.get()+":"+r2.get());
        ex.shutdown();
    }
}

class Mc implements Callable<Integer> {
    private  int begin,end;
    public Mc(int begin,int end){
        this.begin=begin;
        this.end=end;
    }
    @Override
    public Integer call() throws Exception {
        int sum=0;
        for (int i = begin; i < end; i++) {
            sum +=i;
        }
        return sum;
    }
}


© 著作权归作者所有

共有 人打赏支持
噼里啪啦嘣

噼里啪啦嘣

粉丝 1
博文 30
码字总数 8391
作品 0
杭州
后端工程师
私信 提问
JAVA多线程实现的三种方式和带返回值实现

1、JAVA多线程实现的四种方式 继承Thread类 实现Runnable接口 实现Callable接口通过FutureTask包装器来创建Thread线程 使用ExecutorService、Callable、Future实现有返回结果的多线程 2、继承...

职业搬砖20年
06/14
0
0
Java多线程、并发杂记

多线程涉及的类可以分为以下几类: 可执行对象:最基本的多线程 执行器:简化多线程编程 工具类 容器 并发控制 一、可执行对象: 1、Runnable: 执行单位:Thread 创建线程的两种方式(来自于...

rathan0
2016/02/17
60
0
Thread,Runnable,Callable. 多线程

编写多线程程序是为了实现多任务的并发执行,从而能够更好地与用户交互。一般有三种方法,Thread,Runnable,Callable.   Runnable和Callable的区别是,   (1)Callable规定的方法是call(...

千惊万喜
2016/06/30
12
0
Callable,Runnable比较及用法以及创建线程的4种方法

编写多线程程序是为了实现多任务的并发执行,从而能够更好地与用户交互。一般有三种方法,Thread,Runnable,Callable. Runnable和Callable的区别是, (1)Callable规定的方法是call(),Runnable...

geek_loser
2017/10/25
0
0
java多线程编程之Future/FutureTask和Callable

有这样一种场景,用多线程发送数据到某个服务器,需要知道各个线程是否都发送成功,等所有线程都发送完成才能继续下一轮计算和发送。如果用传统的多线程方式,就需要启动多个线程,然后在每个...

上品好礼生活馆
2014/09/11
0
0

没有更多内容

加载失败,请刷新页面

加载更多

Alibaba Java诊断利器Arthas实践--使用redefine排查应用奇怪的日志来源

背景 随着应用越来越复杂,依赖越来越多,日志系统越来越混乱,有时会出现一些奇怪的日志,比如: [] [] [] No credential found 那么怎样排查这些奇怪的日志从哪里打印出来的呢?因为搞不清...

hengyunabc
今天
1
0
home hosts

home hosts lwk@qwfys:~$ cat /etc/hosts127.0.0.1 localhost127.0.1.1 qwfys192.168.56.101vm600.qwfys.com39.108.212.91alpha1.ppy.com39.108.117.122alpha2.p......

qwfys
今天
1
0
大数据教程(6.1)hadoop生态圈介绍及就业前景

1. HADOOP背景介绍 1.1、什么是HADOOP 1.HADOOP是apache旗下的一套开源软件平台 2.HADOOP提供的功能:利用服务器集群,根据用户的自定义业务逻辑,对海量数据进行分布式处理 3.HADOOP的核心组...

em_aaron
今天
4
0
hadoop垃圾回收站

在生产生,hdfs回收站必须是开启的,一般设置为7天。 fs.trash.interval 为垃圾回收站保留时间,如果为0则禁用回收站功能。 fs.trash.checkpoint.interval 回收站检查点时间,一般设置为小于...

hnairdb
昨天
3
0
腾讯与Github的魔幻会面背后的故事…

10月22日,腾讯开源管理办公室有幸邀请到Github新晋CEO Nat Friedman,前来鹅厂参观交流。目前腾讯已经有近70个项目在Github上开源,共获得17w stars,世界排名11位。Github是腾讯开源的主阵...

腾讯开源
昨天
19
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部