import java.util.concurrent.Callable;

import java.util.concurrent.ExecutionException;

import java.util.concurrent.FutureTask;

/**

 * 

 * @author Kaiwii Ho

 * Callable类就是一个有返回值的任务

 * 对于任务与Thread之间的关系,可以这样子理解:

 * Callable类的实例就是一个锦囊妙计;而Thread就是执行这个锦囊妙计的过程

 * 

 * FutureTask类(Future接口的一个实现)就是一个监视器:检测着被若干个异步线程操作的变量的一个类

 * 

 * 代码演示了主线程如何通过使用Callable类和FutureTask类,实现:

 * 主线程一边等待子线程的处理结果,一边完成自己的工作。

 *

 *考虑以下一个小黑工kaiwii的故事……

 */
public class TestFutureTask {

    

    /**

     * @param args

     */

    public static void main(String[] args) {

        // TODO Auto-generated method stub
        //准备一份工作给一个打工仔employee叫Kaiwii
        Employee kaiwii=new Employee("kaiwii");

        //新建一个监工头inspector
        FutureTask<Double>inspector=new FutureTask<Double>(kaiwii);

        //让kaiwii这个打工仔工作
        System.out.println("老板发话,让kaiwii这个打工仔工作吧!");

        new Thread(inspector).start();

        System.out.println("老板开始数钱!");

        //老板一边数钱,一边命令监工inspector监视Kaiwii工作;一旦kaiwii完成工作就拿来让他检查
        while(!inspector.isDone()){

            System.out.println("老板数钱中……");

            try {

                Thread.sleep(500);

            } catch (InterruptedException e) {

                // TODO Auto-generated catch block
                e.printStackTrace();

            }

            

        }

        //老板交监工inspector将kaiwii的结果呈上来以便他验收kaiwii计算出来的结果
        try {

            System.out.println("老板发现kaiwii的结果是:"+inspector.get());

        } catch (InterruptedException e) {

            // TODO Auto-generated catch block
            e.printStackTrace();

        } catch (ExecutionException e) {

            // TODO Auto-generated catch block
            e.printStackTrace();

        }

    }

}

//子线程
class Employee implements Callable<Double>{

    String employee_name;

    

    private void setEmployee_name(String employee_name) {

        this.employee_name = employee_name;

    }

    

    public Employee(String employee_name) {

        setEmployee_name(employee_name);

    }

    @Override

    public Double call() throws Exception {

        // TODO Auto-generated method stub
        System.out.println("工人"+employee_name+"说:我开始工作了!!!!");

        for(int i=1;i<=10;i++){

            System.out.println("工人"+employee_name+" 第"+i+"次说:我在工作呢!!!!");

            Thread.sleep(1000);

        }

        System.out.println("工人"+employee_name+"说:我搞好了!!!!");

        return Math.random();

    }
}

console显示结果:

老板发话,让kaiwii这个打工仔工作吧!

老板开始数钱!

工人kaiwii说:我开始工作了!!!!

工人kaiwii 第1次说:我在工作呢!!!!

老板数钱中……

老板数钱中……

工人kaiwii 第2次说:我在工作呢!!!!

老板数钱中……

老板数钱中……

老板数钱中……

工人kaiwii 第3次说:我在工作呢!!!!

老板数钱中……

老板数钱中……

工人kaiwii 第4次说:我在工作呢!!!!

老板数钱中……

老板数钱中……

工人kaiwii 第5次说:我在工作呢!!!!

老板数钱中……

老板数钱中……

工人kaiwii 第6次说:我在工作呢!!!!

老板数钱中……

老板数钱中……

工人kaiwii 第7次说:我在工作呢!!!!

老板数钱中……

老板数钱中……

工人kaiwii 第8次说:我在工作呢!!!!

老板数钱中……

老板数钱中……

工人kaiwii 第9次说:我在工作呢!!!!

老板数钱中……

老板数钱中……

工人kaiwii 第10次说:我在工作呢!!!!

老板数钱中……

工人kaiwii说:我搞好了!!!!

老板数钱中……

老板发现kaiwii的结果是:0.5295364482450889

callable结合FutureTask的多线程使用(免打扰模式)的更多相关文章

  1. 超赞!IDEA 最新版本,支持免打扰和轻量模式!

    IntelliJ IDEA 2020.1 的第二个早期访问版本已发布,新的 EAP 构建对调试器和事件探查器(Profiler)进行了改进,并引入了新的提交工具窗口(Commit toolwindow ...

  2. 基于接口回调详解JUC中Callable和FutureTask实现原理

    Callable接口和FutureTask实现类,是JUC(Java Util Concurrent)包中很重要的两个技术实现,它们使获取多线程运行结果成为可能.它们底层的实现,就是基于接口回调技术. ...

  3. java Runnable、Callable、FutureTask 和线程池

    一:Runnable.Callable.FutureTask简介 (1)Runnable:其中的run()方法没有返回值. ①.Runnable对象可以直接扔给Thread创建线程实例,并且创建的线程 ...

  4. Java 并发编程——Callable+Future+FutureTask

    Java 并发编程系列文章 Java 并发基础——线程安全性 Java 并发编程——Callable+Future+FutureTask java 并发编程——Thread 源码重新学习 java并发 ...

  5. 12 Callable & Future & FutureTask

    创建线程的2种方式,一种是直接继承Thread,另外一种就是实现Runnable接口. 这2种方式都有一个缺陷就是:在执行完任务之后无法获取执行结果. 如果需要获取执行结果,就必须通过共享变量或者使用 ...

  6. Java多线程编程中Future模式的详解

    Java多线程编程中,常用的多线程设计模式包括:Future模式.Master-Worker模式.Guarded Suspeionsion模式.不变模式和生产者-消费者模式等.这篇文章主要讲述Futu ...

  7. Java多线程编程中Future模式的详解<转>

    Java多线程编程中,常用的多线程设计模式包括:Future模式.Master-Worker模式.Guarded Suspeionsion模式.不变模式和生产者-消费者模式等.这篇文章主要讲述Futu ...

  8. 【多线程】--生产者消费者模式--Lock版本

    在JDK1.5发布后,提供了Synchronized的更优解决方案:Lock 和 Condition 我们使用这些新知识,来改进例子:[多线程]--生产者消费者模式--Synchronized版本 改 ...

  9. java多线程-消费者和生产者模式

    /* * 多线程-消费者和生产者模式 * 在实现消费者生产者模式的时候必须要具备两个前提,一是,必须访问的是一个共享资源,二是必须要有线程锁,且锁的是同一个对象 * */ /*资源类中定义了name( ...

  10. Java多线程_生产者消费者模式2

    在我的上一条博客中,已经介绍到了多线程的经典案列——生产者消费者模式,但是在上篇中用的是传统的麻烦的非阻塞队列实现的.在这篇博客中我将介绍另一种方式就是:用阻塞队列完成生产者消费者模式,可以使用多种阻 ...

随机推荐

  1. SciPy从入门到放弃

    目录 SciPy简介 拟合与优化模块 求最小值 曲线拟合 线性代数模块 统计模块 直方图和概率密度函数 统计检验 SciPy简介 SciPy是一种以NumPy为基础,用于数学.工程及许多其他的科学任务 ...

  2. Angular 18+ 高级教程 – Signals

    前言 首先,我必须先说明清楚.Signal 目前不是 Angular 的必备知识. 你的项目不使用 Signal 也不会少了条腿,断了胳膊. Angular 官方维护的 UI 组件库 Angular ...

  3. SQL Server – Transaction & Isolation 事务与隔离

    前言 上回在谈到 Concurrency 并发控制 时, 有提到过事务的概念. 这篇就补上它具体的实现. 以前写过相关的文章: sql server 学习笔记 (nested transaction ...

  4. CSS & JS Effect – Tooltip

    介绍 Tooltip 长这样 它用 popup 的方式来详细描述一个主体. 比如某个 icon 代表着什么. 参考 YouTube – How To Make Tooltips With Only C ...

  5. Figma 学习笔记 – Frame

    Frame = <div> Frame 就类似 HTML 中的 div, 它和形状 rectangle 特性上蛮相识的, 但是使用场景其实差很多, 所以不要搞错哦. (除了图片很少会用到 ...

  6. 使用 Flutter 3.19 更高效地开发

    我们已隆重推出全新的 Flutter 版本--Flutter 3.19.此版本引入了专为 Gemini 设计的新 Dart SDK.一个能让开发者对 Widget 动画实现精细化控制的全新 Widge ...

  7. Java项目笔记(一)

    一.springboot控制台打印sql日志 ---------.mapper为你启动类扫描的mapper路径 logging.level.---------.mapper = debug 二.前端传 ...

  8. 【USB3.0协议学习】Topic1·USB3.0Hub的一些机制

    一.USB3.0 Hub的单播(非广播)机制 Hub通过解析下行packet header中的Route String字段识别packet要传递的终点,其中4'b0000代表hub本身,4'b0001 ...

  9. Java实用小工具系列1---使用StringUtils分割字符串

    经常有这种情况,需要将逗号分割的字符串,比如:aaa, bbb ,ccc,但往往是人工输入的,难免会有多空格逗号情况,比如:aaa, bbb , ccc, ,,这种情况使用split会解析出不正常的结 ...

  10. typeof typeof 'texs'是什么类型

    typeof '12' 返回  'string' 是字符串类型  :