`
弦上的福音
  • 浏览: 21807 次
  • 性别: Icon_minigender_1
  • 来自: 南京
社区版块
存档分类
最新评论

Java多线程之Callable接口的实现 (转)

    博客分类:
  • java
阅读更多
本文转自
http://aloys.iteye.com/blog/630135



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();     
    }     
    
}

分享到:
评论

相关推荐

    Java多线程之Callable接口的实现

    Java多线程之Callable接口的实现 Java中的多线程编程是指在一个程序中同时运行多个线程,以提高程序的执行效率和响应速度。在Java中,有两种方式可以实现多线程编程,即继承Thread类和实现Runnable接口。然而,在...

    Java多线程实现Callable接口

    通过以上知识点,我们可以看到Callable接口在Java多线程中的应用,它可以方便地处理返回值,并且与ExecutorService结合,提供了强大的并发处理能力。在实际开发中,特别是在大数据处理、计算密集型任务等场景下,...

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

    Java 多线程 Callable 接口实现代码示例 Java 多线程编程中,创建线程有多种方式,其中一种便是实现 Callable 接口。Callable 接口是一个函数式接口,定义了一个 call 方法,该方法可以抛出异常并返回结果。与 ...

    Java多线程Callable和Future接口区别

    Java多线程Callable和Future接口的使用场景非常广泛,如计算复杂的数学问题、处理大规模数据、实现高性能的服务器等等。在这些场景中,我们可以使用Callable和Future接口来实现异步计算,从而提高系统的性能和可扩展...

    Java多线程Callable接口

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

    Java使用Callable和Future创建线程操作示例

    1. 创建Callable接口的实现类,并实现call()方法,该call()方法将作为该线程的执行体,且该call()方法有返回值,再创建Callable的实例。从Java 8开始,可以直接使用Lamda表达式创建Callable对象。 2. 使用...

    java callable(多线程)

    ### Java Callable与多线程详解 在Java编程中,`Callable`接口是...通过以上分析和示例,我们可以看到`Callable`和`Future`在Java多线程编程中的强大功能,尤其是在需要处理复杂的异步任务和需要返回结果的情况下。

    java实现多线程文件传输

    在Java编程语言中,实现多线程文件传输是一种优化程序性能、提高系统资源...在提供的`java多线程文件传输`压缩包中,可能包含了实现这些概念的示例代码,通过分析和学习,可以更好地理解多线程文件传输的原理和实践。

    java多线程实现大批量数据导入源码

    本项目以"java多线程实现大批量数据导入源码"为题,旨在通过多线程策略将大量数据切分,并进行并行处理,以提高数据处理速度。 首先,我们需要理解Java中的线程机制。Java通过`Thread`类来创建和管理线程。每个线程...

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

    Java Callable接口实现多线程的方式详解 Java Callable接口是Java 1.5中引入的一种多线程实现方式,用于解决传统线程创建方式的缺陷。 Callable接口和Future接口的组合使用,能够实现多线程并发执行任务,并获取...

    汪文君JAVA多线程编程实战(完整不加密)

    《汪文君JAVA多线程编程实战》是一本专注于Java多线程编程的实战教程,由知名讲师汪文君倾力打造。这本书旨在帮助Java开发者深入理解和熟练掌握多线程编程技术,提升软件开发的效率和质量。在Java平台中,多线程是...

    Java多线程技术精讲

    Java多线程技术是Java编程中的重要组成部分,它允许程序同时执行多个任务,极大地提高了程序的效率和响应性。在现代计算机系统中,多线程是实现并发处理的关键技术,尤其在服务器端应用和高性能计算中不可或缺。 ...

    java多线程处理数据库数据

    然而,为了更好地管理和控制线程,Java并发包提供了如`ExecutorService`、`Future`、`Callable`等高级接口和类,它们简化了多线程编程,并提供了更好的资源管理。 在处理数据库数据时,我们通常会使用JDBC(Java ...

    JAVA 多线程的PPT和示例

    Java多线程是Java编程中的一个核心概念,它允许程序同时执行多个独立的任务,从而提高应用程序的效率和响应性。在Java中,多线程主要通过两种方式实现:继承Thread类和实现Runnable接口。这份"JAVA多线程的PPT和示例...

    Java多线程.pdf

    Java多线程的实现方式主要有三种:继承Thread类、实现Runnable接口以及实现Callable接口。 1. 继承Thread类: 当自定义类继承Thread类时,需要重写run()方法来定义线程的行为。然后通过创建Thread子类的对象并调用...

    Java多线程设计模式_清晰完整PDF版 Java多线程设计模式源代码

    总之,Java多线程设计模式是每个Java开发者必备的技能之一。深入学习并熟练运用这些模式,将有助于你编写出更高效、稳定和易于扩展的多线程应用程序。这个PDF版教程和源代码集合是你学习多线程设计模式的理想资源,...

    Java多线程程序设计

    Java多线程程序设计是Java开发中的重要领域,它允许应用程序同时执行多个任务,从而提高系统资源的利用率和程序的响应速度。在Java中,多线程主要通过两种方式实现:继承Thread类和实现Runnable接口。 一、创建线程...

    java 多线程示例

    Java多线程是Java编程中的重要概念,尤其在开发高性能、高并发的应用中不可或缺。本示例旨在为初学者提供一个全面理解Java多线程的起点。通过学习这个实例,你可以掌握如何创建和管理线程,理解线程同步与通信的重要...

    java多线程编程

    Java多线程编程是Java开发中的重要组成部分,它允许程序同时执行多个任务,极大地提高了程序的效率和响应性。在Java中,多线程主要通过继承Thread类或实现Runnable接口来实现。本教程将深入探讨Java多线程的各个方面...

Global site tag (gtag.js) - Google Analytics