- 浏览: 44434 次
- 性别:
- 来自: 成都
文章分类
最新评论
- 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();
- }
-
}
发表评论
-
JDK里的设计模式
2010-12-13 17:24 708Structural(结构模式) Adapte ... -
Java总结
2010-12-11 18:09 7751. 关于动态加载机制?? 学习Java比C++更容易理解 ... -
Java核心技术对泛型设计的总结(1) 通配符
2010-11-30 23:34 695Java 通配符主要用来解决泛型设计中类型约束中继承概念 ... -
Java核心技术对泛型设计的总结(1) 限制与约束
2010-11-30 23:17 9531 Java 泛型设计中的一 ... -
could not open %JAVA_HOME%\lib\i386\jvm.cfg
2010-10-22 22:19 849今天无聊换了个JDK...直接把别人机器上的JDK拷贝过来,出 ... -
int 和 String 互相转换的多种方法
2010-06-06 21:11 7231 如何将字串 String 转换成整数 int? A. ... -
java正则表达式应用
2010-06-06 11:47 694首先说一下java正则表达式的重点概念: 第一、相关类:P ... -
(转载)经典兔子数列(斐波那契数列)算法(公布3种)
2010-05-31 00:22 1787斐波那契数列又因数学家列昂纳多·斐波那契以兔子繁殖为例子而引入 ... -
斐波那契数列 农夫养牛问题
2010-05-31 00:18 888记下来自己看的。 问题: (CSDN上看到的) ... -
斐波那契数列算法
2010-05-31 00:18 906首先介绍一下什么是斐波那契数列:1,1,2,3,5,8,13, ... -
class文件常量池中字符串类 urf8格的存储格式
2010-05-29 15:56 934java虚拟机在class文件中对应类型的常量池中使用了一种类 ... -
[转]java中equals和==的区别
2010-05-24 12:52 679值类型是存储在内存中的堆栈(以后简称栈),而引用类型的变量在栈 ...
相关推荐
Java多线程Callable和Future接口的使用场景非常广泛,如计算复杂的数学问题、处理大规模数据、实现高性能的服务器等等。在这些场景中,我们可以使用Callable和Future接口来实现异步计算,从而提高系统的性能和可扩展...
Runnable是执行工作的独立任务,但是它不返回任何值,如果你希望任务在完成时能够返回一个值,那么可以实现Callable接口而不是Runnable接口。在Java SE5中引入的Callable是一种具有类型参数的泛型,它的类型参数表示...
本项目以"java多线程实现大批量数据导入源码"为题,旨在通过多线程策略将大量数据切分,并进行并行处理,以提高数据处理速度。 首先,我们需要理解Java中的线程机制。Java通过`Thread`类来创建和管理线程。每个线程...
### Java Callable与多线程详解 在Java编程中,`Callable`接口是...通过以上分析和示例,我们可以看到`Callable`和`Future`在Java多线程编程中的强大功能,尤其是在需要处理复杂的异步任务和需要返回结果的情况下。
Java 多线程 Callable 接口实现代码示例 Java 多线程编程中,创建线程有多种方式,其中一种便是实现 Callable 接口。Callable 接口是一个函数式接口,定义了一个 call 方法,该方法可以抛出异常并返回结果。与 ...
《汪文君JAVA多线程编程实战》是一本专注于Java多线程编程的实战教程,由知名讲师汪文君倾力打造。这本书旨在帮助Java开发者深入理解和熟练掌握多线程编程技术,提升软件开发的效率和质量。在Java平台中,多线程是...
1. 创建Callable接口的实现类,并实现call()方法,该call()方法将作为该线程的执行体,且该call()方法有返回值,再创建Callable的实例。从Java 8开始,可以直接使用Lamda表达式创建Callable对象。 2. 使用...
本主题将深入探讨如何使用Java的并发包(java.util.concurrent)来实现多线程对数据库数据的批量处理,包括增、删、改等操作。 首先,我们需要了解Java中的线程基础。线程是程序执行的最小单位,一个进程可以包含多...
在Java编程语言中,实现多线程文件传输是一种优化程序性能、提高系统资源...在提供的`java多线程文件传输`压缩包中,可能包含了实现这些概念的示例代码,通过分析和学习,可以更好地理解多线程文件传输的原理和实践。
Java多线程技术是Java编程中的重要组成部分,它允许程序同时执行多个任务,极大地提高了程序的效率和响应性。在现代计算机系统中,多线程是实现并发处理的关键技术,尤其在服务器端应用和高性能计算中不可或缺。 ...
总结来说,Java 5的并发库大大提升了Java多线程编程的效率和易用性,通过线程池、阻塞队列、可重入锁以及Callable和Future接口,我们可以构建高效、线程安全的并发程序。在这个网络服务器模型中,我们看到了这些特性...
Java多线程设计模式是Java开发中的重要领域,它涉及到如何在并发环境下高效、安全地管理资源和控制程序执行流程。本资料集包含了清晰完整的PDF版书籍和源代码,为学习和理解Java多线程设计模式提供了丰富的素材。 ...
通过以上知识点,我们可以看到Callable接口在Java多线程中的应用,它可以方便地处理返回值,并且与ExecutorService结合,提供了强大的并发处理能力。在实际开发中,特别是在大数据处理、计算密集型任务等场景下,...
Java多线程是Java编程中的重要概念,尤其在开发高性能、高并发的应用中不可或缺。本示例旨在为初学者提供一个全面理解Java多线程的起点。通过学习这个实例,你可以掌握如何创建和管理线程,理解线程同步与通信的重要...
Java多线程是Java编程中的一个核心概念,它允许程序同时执行多个独立的任务,从而提高应用程序的效率和响应性。在Java中,多线程主要通过两种方式实现:继承Thread类和实现Runnable接口。这份"JAVA多线程的PPT和示例...
Java多线程的实现方式主要有三种:继承Thread类、实现Runnable接口以及实现Callable接口。 1. 继承Thread类: 当自定义类继承Thread类时,需要重写run()方法来定义线程的行为。然后通过创建Thread子类的对象并调用...
总结来说,实现"java多线程实现乒乓球双打"需要对Java的线程API有深入的理解,包括线程的创建与启动、同步与通信机制、并发控制工具的使用以及设计模式的应用。通过这种方式,我们可以构建出一个生动有趣的模拟游戏...
Java多线程编程是Java开发中的重要组成部分,它允许程序同时执行多个任务,极大地提高了程序的效率和响应性。在Java中,多线程主要通过继承Thread类或实现Runnable接口来实现。本教程将深入探讨Java多线程的各个方面...
Java多线程应用实现主要涉及两种方式:继承Thread类和实现Runnable接口。这两种方法都是为了在Java程序中创建并管理多个并发执行的任务,从而提高程序的执行效率。 1. 继承Thread类: 当一个类直接继承Thread类时,...
Java多线程学习是编程领域中的重要一环,特别是在服务器端和网络编程中,多线程技术能够有效地利用系统资源,提高程序的并发性。FTP(File Transfer Protocol)上传则是通过网络将本地文件传输到远程服务器的过程。...