`
xiangkun
  • 浏览: 99846 次
  • 性别: Icon_minigender_1
  • 来自: 马尔代夫
社区版块
存档分类
最新评论

Java多线程之Callable接口的实现

阅读更多
import java.util.concurrent.Callable;   
import java.util.concurrent.ExecutorService;   
import java.util.concurrent.Executors;   
import java.util.concurrent.Future;   
  
/** *//**  
 * Callable 和 Future接口  
 * Callable是类似于Runnable的接口,实现Callable接口的类和实现Runnable的类都是可被其它线程执行的任务。  
 * Callable和Runnable有几点不同:  
 * (1)Callable规定的方法是call(),而Runnable规定的方法是run().  
 * (2)Callable的任务执行后可返回值,而Runnable的任务是不能返回值的。  
 * (3)call()方法可抛出异常,而run()方法是不能抛出异常的。  
 * (4)运行Callable任务可拿到一个Future对象,  
 * Future 表示异步计算的结果。它提供了检查计算是否完成的方法,以等待计算的完成,并检索计算的结果。  
 * 通过Future对象可了解任务执行情况,可取消任务的执行,还可获取任务执行的结果。  
 */  
public class CallableAndFuture {   
  
    /** *//**  
     * 自定义一个任务类,实现Callable接口  
     */  
    public static class MyCallableClass implements Callable{   
        // 标志位   
        private int flag = 0;   
        public MyCallableClass(int flag){   
            this.flag = flag;   
        }   
        public String call() throws Exception{   
            if (this.flag == 0){   
                // 如果flag的值为0,则立即返回   
                return "flag = 0";   
            }    
            if (this.flag == 1){   
                // 如果flag的值为1,做一个无限循环   
                try {   
                    while (true) {   
                        System.out.println("looping.");   
                        Thread.sleep(2000);   
                    }   
                } catch (InterruptedException e) {   
                    System.out.println("Interrupted");   
                }   
                return "false";   
            } else {   
                // falg不为0或者1,则抛出异常   
                throw new Exception("Bad flag value!");   
            }   
        }   
    }   
       
    public static void main(String[] args) {   
        // 定义3个Callable类型的任务   
        MyCallableClass task1 = new MyCallableClass(0);   
        MyCallableClass task2 = new MyCallableClass(1);   
        MyCallableClass task3 = new MyCallableClass(2);   
           
        // 创建一个执行任务的服务   
        ExecutorService es = Executors.newFixedThreadPool(3);   
        try {   
            // 提交并执行任务,任务启动时返回了一个 Future对象,   
            // 如果想得到任务执行的结果或者是异常可对这个Future对象进行操作   
            Future future1 = es.submit(task1);   
            // 获得第一个任务的结果,如果调用get方法,当前线程会等待任务执行完毕后才往下执行   
            System.out.println("task1: " + future1.get());   
               
            Future future2 = es.submit(task2);   
            // 等待5秒后,再停止第二个任务。因为第二个任务进行的是无限循环   
            Thread.sleep(5000);   
            System.out.println("task2 cancel: " + future2.cancel(true));   
               
            // 获取第三个任务的输出,因为执行第三个任务会引起异常   
            // 所以下面的语句将引起异常的抛出   
            Future future3 = es.submit(task3);   
            System.out.println("task3: " + future3.get());   
        } catch (Exception e){   
            System.out.println(e.toString());   
        }   
        // 停止任务执行服务   
        es.shutdownNow();   
    }   
}  
分享到:
评论
6 楼 bo_hai 2014-05-09  
future2.cancel(true)); 


不能停止。
5 楼 ldci3gandroid 2013-07-25  
讲解的清晰易懂,实在难得,很受益。
4 楼 esirong 2012-12-06  
学习了
清晰明白
3 楼 stevenjohn 2012-10-09  
太犀利了,楼猪
2 楼 lxl8129 2011-09-01  
讲解知识点就该用这种简单的例子嘛,简单,易懂!谢谢啊
1 楼 blackartanan 2011-03-19  
多谢楼主的分享 正是我所需要的

相关推荐

    Java多线程实现Callable接口

    本文给大家分享的是使用Java多线程来实现callable接口的方法,以及使用方法,另外还有一个网友的实例,希望能够对大家掌握Java多线程有所帮助。

    Java多线程Callable接口

    Runnable是执行工作的独立任务,但是它不返回任何值,如果你希望任务在完成时能够返回一个值,那么可以实现Callable接口而不是Runnable接口。在Java SE5中引入的Callable是一种具有类型参数的泛型,它的类型参数表示...

    Java多线程Callable接口实现代码示例

    相信大家对Java编程中如何创建线程已经不陌生了,这篇文章就向朋友们介绍实现callable接口,具体实例详见正文。

    Java多线程Callable和Future接口区别

    主要介绍了Java多线程Callable和Future接口区别,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下

    计算机后端-Java-Java核心基础-第20章 多线程 18. 创建多线程的方式三:实现Callable接口.avi

    计算机后端-Java-Java核心基础-第20章 多线程 18. 创建多线程的方式三:实现Callable接

    详解Java Callable接口实现多线程的方式

    主要介绍了详解Java Callable接口实现多线程的方式,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

    java多线程编程 新api

    java 多线程编程 很实用 来自网上 1)包括新api介绍 2)新线程接口 Callable 和 Future 的讲解 3)线程同步知识

    java多线程学习

    java多线程学习,常见实现线程的方式,继承Thread类,实现Runnable接口,实现Callable接口

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

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

    Java多线程-JDK5.0新增线程创建方式

    Java多线程--JDK5.0新增线程创建方式

    多线程机制

    7、 浅析 Java Thread.join() : java多线程实现主线程等待所有子线程执行完毕 16 8、 线程运行中抛出异常的处理 19 9、 Callable 有返回值的线程 20 10、 Callable结合FutureTask的多线程使用(免打扰模式) 24

    讲给女朋友听的java多线程(2万字深入理解多线程,有实例代码辅助理解)

    实现Callable接口4. 使用线程池线程的调度线程的生命周期线程同步1. 方法一:同步代码块2. 方法二:同步方法3. 方法三:Lock(锁):4. 对比三种方法5. 典型例题6. 线程死锁问题线程通信两个方法sleep()方法和wait()...

    个人总结的深入java多线程开发

    看完《think in java》多线程章节,自己写的多线程文档,还结合了其他的相关网络资料。 线程 一. 线程池 1)为什么要使用线程池 2 2)一个具有线程池的工作队列 3 3)使用线程池的风险: 4 4)有效使用线程池的原则 5...

    一篇文章弄懂Java多线程基础和Java内存模型

    文章目录一、多线程的生命周期及五种基本状态二、Java多线程的创建及启动1.继承Thread类,重写该类的run()方法2.通过实现Runnable接口创建线程类3.通过Callable和Future接口创建线程三、Java内存模型概念四、内存间...

    多线程例子

    在java中要想实现多线程,有两种手段,一种是继续Thread类,另外一种是实现Runable接口.(其实准确来讲,应该有三种,还有一种是实现Callable接口,并与Future、线程池结合使用,此文这里不讲这个。

    突破JAVA万人面试,懂多线程者得天下.zip

    06线程创建实现 Callable接口avi 07线程创建线程池创建线程avi 08线程创建小结av 09线程生命周期avi 10.线程安全问题什么是线程安全avi 11线程安全同题问题分析avi 12线程安全问题线程安全问题演示avi ................

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

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

    Java多线程详解

    文章目录1、进程与线程2、创建多线程2.1、继承Thread类2.2、实现Runnable接口2.3、使用匿名内部类实现2.4、实现Runnable接口的好处2.5、使用Callable和Future创建线程3、线程的生命周期4、几种特殊线程4.1、join线程...

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

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

Global site tag (gtag.js) - Google Analytics