Java--Callable与返回值future
- package com;
- import java.util.concurrent.*;
- /**
- * Created by yangyu on 16/11/28.
- */
- /**
- * Callable and Future用法
- * Callable可以被ExecutorService的submit方法使用,可以取线程执行的返回值;
- *
- * Future是返回值的封装类型:
- * get()方法阻塞当前线程直到获取到返回值
- * isDone()方法判断线程是否执行完成
- * isCancelled()方法判断线程是否被中断
- * cancel(boolean mayInterruptIfRunning)方法中断线程,但是线程方法内必须有中断判断interrupted(),否则是无法中断线程的
- */
- public class TestCallableAndFuture {
- private static class Data{
- public int sum;
- }
- /**
- * Callable实现
- */
- private static class TaskCall implements Callable<Integer>{
- @Override
- public Integer call() throws Exception {
- int sum = 0;
- for (int i = 0; i < 1000; i++) {
- sum = sum+i;
- }
- return sum;
- }
- }
- /**
- * Runnable实现,并且判断了线程是否被中断interrupted()
- */
- private static class TaskRun implements Runnable{
- private Data data;
- TaskRun(Data data){
- this.data = data;
- }
- @Override
- public void run() {
- for (int i = 0; i < 10000; i++) {
- /**
- * 判断线程如果被中断则跳出循环
- */
- if (Thread.interrupted())
- break;
- data.sum = data.sum+i;
- }
- }
- }
- public static void main(String[] args) {
- Data data = new Data();
- /**
- * 初始化一个可缓存线程池
- */
- ExecutorService executorService = Executors.newCachedThreadPool();
- /**
- * submit方法执行Callable
- */
- Future<Integer> future1= executorService.submit(new TaskCall());
- /**
- * submit方法执行Runnable,其实future就是对data的封装,实际上使用future.get()返回的是data的引用
- */
- Future<Data> future2 = executorService.submit(new TaskRun(data),data);
- try {
- System.out.println("future1 isCancelled:"+future1.isCancelled());
- System.out.println("future1 result:"+future1.get());
- System.out.println("future1 isDone:"+future1.isDone());
- /**
- * 中断线程
- */
- //future2.cancel(true);
- if (!future2.isCancelled())
- {
- System.out.println("future2 result:"+future2.get().sum);
- System.out.println("future2 isDone:"+future2.isDone());
- }
- System.out.println(data.sum);
- } catch (InterruptedException e) {
- e.printStackTrace();
- } catch (ExecutionException e) {
- e.printStackTrace();
- }
- System.out.println("完成");
- }
- }
Java--Callable与返回值future的更多相关文章
- paip.java 多线程参数以及返回值Future FutureTask 的使用.
paip.java 多线程参数以及返回值Future FutureTask 的使用. 在并发编程时,一般使用runnable,然后扔给线程池完事,这种情况下不需要线程的结果. 所以run的返回值是vo ...
- Java多线程带返回值的Callable接口
Java多线程带返回值的Callable接口 在面试的时候,有时候是不是会遇到面试会问你,Java中实现多线程的方式有几种?你知道吗?你知道Java中有可以返回值的线程吗?在具体的用法你知道吗?如果两 ...
- 在Java 线程中返回值的用法
http://icgemu.iteye.com/blog/467848 在Java 线程中返回值的用法 博客分类: Java Javathread 有时在执行线程中需要在线程中返回一个值:常规中我们 ...
- 测试 多线程 实现 callable 带返回值
package threadTest; import java.util.ArrayList; import java.util.Date; import java.util.concurrent.C ...
- java 代码执行cmd 返回值异常 (关于JAVA Project.waitfor()返回值是1)
关于JAVA Project.waitfor()返回值是1 0条评论 Project.waitfor()返回值是1,找了很久从网上没有发现关于1的说明. 这时对源代码调试了一下,发现Project ...
- 为什么Java不能以返回值区分重载方法?
读者可能会想:"在区分重载方法的时候,为什么只能以类名和方法的形参列表作为标准呢?能否考虑用方法的返回值来区分呢?" 比如下面两个方法,虽然他们有相同的名字和形式参数,但却很容易区 ...
- 谁说java里面有返回值的方法必须要有返回值,不然会报错????
慢慢的总是发现以前的学得时候有些老师讲的不对的地方! 所以还是尽量别把一些东西说的那么绝对,不然总是很容易误导别人,特别是一些你自己根本就没有试过的东西,然后又斩钉截铁的告诉别人,这样不行,肯定不行什 ...
- java递归算法提前返回值带出
/** * */ package testJava.java.foreach; import java.util.ArrayList; import java.util.LinkedList; imp ...
- 10-02 Java 形式参数和返回值的问题深入研究,链式编程
形式参数和返回值的问题: 1:形式参数和返回值的问题(理解) (1)形式参数: 类名:需要该类的对象 抽象类名:需要该类的子类对象 接口名:需要该接口的实现类对象 (2)返回值类型: 类名:返回的是该 ...
随机推荐
- IOS SWIFT 启动流程学习
其实和我们java.c一样通过一个main函数作为入口. main封装在了UIApplicationMain里面.所以后者变成启动入口. 他会扫描Info.plist,找到需要加载的入口storybo ...
- Python virtualenv with Sublime Text 3
背景介绍 最近喜欢上了Sublime编辑器,刚开始学着用.不过对我这个python狂人来讲,首要问题是需要sublime支持python virtualenv包的导入.所以我就找了google最后找到 ...
- css双飞翼布局
双飞翼布局是一种比较灵活的布局,始于淘宝UED,玉伯提出的,他着重介绍的是双飞翼栅格布局. 三列布局为"双飞燕"布局,可以把三栏比作一只鸟,main部分相当是于鸟的身体,而lef ...
- MVC validate.js下使用 ajaxSubmit
首页定义验证实体 using System.ComponentModel.DataAnnotations; using System.Web.Mvc; namespace MvcApplication ...
- salesforce 零基础学习(五十)自定义View或者List以及查看系统原来的View或者List
salesforce给我们提供了标准的页面,比如标准的页面包括标准的列表和标准的详细页视图.有的时候我们想要自定义视图,比如做一个项目的时候不希望使用者直接通过ID查看到标准的详细页,而是跳转到指定处 ...
- MyEclipse中屏蔽js检验
方法一: 右键工程-->properties-->Myeclipse-->validation-->Excluded Resource,勾选需要取消验证的文件或者文件夹就可以了 ...
- Redux
redux是Flux的一种实现方式,但还是和Flux有些不同. React控制视图层,要想做一个完整的数据流,必须要用react-redux. 官方demo,自己收集了一下: demo1http:// ...
- 手把手教你用nodejs+SQL Server2012做增删改查
1.开发工具WebStorm 10.0.4 2.打开WebStorm 10.0.4新建项目:
- Js权限判断处理
主要实现自动处理视频点击判断权限. function lookVideo() { var review_con = document.getElementById("review" ...
- jquery实现的网页选项卡(拾忆)
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...