`
jonson
  • 浏览: 169231 次
  • 性别: Icon_minigender_1
  • 来自: 杭州
社区版块
存档分类
最新评论

java.util.concurrent包开发实例

    博客分类:
  • java
阅读更多
从JDK5.0开始,JDK中加入了并发包,最近刚开始使用。感觉对于应用开发非常方便。在开发过程中,我自己碰到两种情况的应用场景。就从应用场景来分析concurrent包的应用。

场景一:任务的定时、延时执行。比如指定某个状态检查的任务程序定时执行。

场景二:有多任务同时提交,而且这些任务相互独立。这些任务可以并行执行的,但是,各个任务最终需要返回执行的结果。

场景一是非常常见的,当然也已经有很多成熟的机制来实现它,比如:定时器Timer。在并发包中接口java.util.concurrent.

ScheduledExecutorService可以非常轻松地完成定时,延时执行,同时可以返回执行结果。通过ScheduledFuture接口跟踪任务执行情况,并获取执行结果。
例如:如下代码:

import static java.util.concurrent.TimeUnit.*;
class BeeperControl {
    private final ScheduledExecutorService scheduler =
       Executors.newScheduledThreadPool(1);

    public void beepForAnHour() {
        final Runnable beeper = new Runnable() {
                public void run() { System.out.println("beep"); }
            };
        final ScheduledFuture<?> beeperHandle =
            scheduler.scheduleAtFixedRate(beeper, 10, 10, SECONDS);
        scheduler.schedule(new Runnable() {
                public void run() { beeperHandle.cancel(true); }
            }, 60 * 60, SECONDS);
    }
}
场景二中,对于并发执行其实并不难,但是如果说要得到执行结果,就比较复杂,主要困难在于任务执行完之后如何获取执行结果,所有任务执行结束之后,如何提醒父进程。在并发实用包中提供的ExecutorService 接口来发起任务,及得到跟踪任务的执行状况的Future的方法。

实例代码如下:

class App {
   ExecutorService executor = ...
   ArchiveSearcher searcher = ...
   void showSearch(final String target) throws InterruptedException {
     Future<String> future = executor.submit(new Callable<String>() {
         public String call() { return searcher.search(target); }
     });
     displayOtherThings(); // do other things while searching
     try {
       displayText(future.get()); // use future
     } catch (ExecutionException ex) { cleanup(); return; }
   }
}
这里实现的Future对象,在取结果的时候是阻塞的,直到该项任务返回结果。因此只要对获取的future对象做操作,即可以控制程序的执行顺序。

最后写一些想法:其实并发程序在很多时候能够极大地加快执行的效率,现在比较流行的多机器联合工作,其实完全可以用这套并行机制来实现。分服务器和任务机,服务器负责分解任务,任务机负责执行任务并返回结果,服务器负责收集结果并且整合。对于简单模型的可拆解任务,完全可以实现。对于复杂的如:多个结果间具有顺序关系,结果相互影响等就比较麻烦。
分享到:
评论
8 楼 sequin 2010-05-26  
现在的电信企业应用中,多数接口都是第二种情况。
7 楼 piper 2010-05-11  
为什么要beeperHandle.cancel(true);
6 楼 tvjody 2010-01-05  
标题党,看似有点内容,进来却东拉西扯的,不全面不系统,能不能研究透了再写啊
5 楼 mathgl 2009-12-22  
fork-join....
4 楼 jonson 2009-12-21  
只是工作中遇到的两个场景。
但是我认为,第二个场景是concurrent包的核心功能,多任务的并发,并且结果返回。
3 楼 faylai 2009-12-21  
标题不错,只是没说什么实质内容。
2 楼 diggywang 2009-12-20  
你的两个场景并不是Concurrent最合适的用武之地,完全是异步处理和回调所做的事情。
1 楼 nj_first 2009-12-19  
标题不错,只是没说什么实质内容。

相关推荐

    深入Synchronized和java.util.concurrent.locks.Lock的区别详解

    《深入Synchronized与java.util.concurrent.locks.Lock的区别详解》 Synchronized和java.util.concurrent.locks.Lock都是Java中用于实现线程同步的关键字和接口,它们的主要目标是保证多线程环境下的数据一致性与...

    Java并发工具包java.util.concurrent用户指南中英文对照阅读版pdf

    在进行Java并发编程时,掌握java.util.concurrent包的知识对于提高开发效率和保障程序稳定运行都是非常必要的。通过深入理解其中的类和接口,程序员可以更好地设计出既高效又可靠的并发应用程序。

    30个常用java工具类

    8. **`java.util.concurrent`** 包:提供并发工具类,如`ExecutorService`、`Future`和`Semaphore`,帮助管理线程和控制并发。 9. **`java.util.Map.Entry`**:表示Map中的键值对,常用于遍历Map。 10. **`java....

    28个java常用的工具类

    23. **`java.util.concurrent.locks.Lock`** 和 **`java.util.concurrent.locks.ReentrantLock`**: 锁机制,用于线程同步。 24. **`java.util.ArrayList`**: 用于创建堆栈、队列和双端队列的实现,如`ArrayDeque`。...

    java工具类

    11. **`java.util.concurrent`** 包:包含并发和多线程工具,如`ExecutorService`、`Future`和`Callable`。 12. **`java.util.logging.Logger`**:日志记录工具,用于输出程序运行时的信息。 13. **`java.lang....

    JAVA开发常用工具类

    8. **`java.util.concurrent` 包**: 提供了线程安全的数据结构和并发工具,如`ExecutorService`、`Semaphore`、`CountDownLatch`等,帮助开发者处理多线程环境下的问题。 9. **`java.io` 包**: 包含了输入输出...

    Java.API文档中文版

    4. **多线程**:Java内置了对多线程的支持,`java.lang.Thread`类和`java.util.concurrent`包提供了线程创建、同步、并发工具类等功能,帮助开发者构建高效的多线程程序。 5. **I/O与NIO**:`java.io`和`java.nio`...

    JavaAPI(官方英文版)

    13. **并发编程(Concurrency)**:`java.util.concurrent`包提供了高效率的并发工具,如`ExecutorService`、`Future`、`Semaphore`等,以及原子变量类(`Atomic*`)。 通过深入学习和理解Java API,开发者可以有效...

    Java计时器

    其次,`java.util.concurrent.ScheduledExecutorService` 是Java并发包(java.util.concurrent)中的接口,它提供了更强大和灵活的定时任务调度功能。我们可以使用`Executors`类的静态方法创建一个...

    java.util源码-sourcecode:utilJava代码

    6. **并发工具类**:`java.util.concurrent`包扩展了`java.util`,提供了线程安全的数据结构和并发控制工具。虽然不在`java.util`包内,但与其紧密相关,如ConcurrentHashMap、AtomicInteger等。 7. **枚举(Enum)...

    java常用工具类

    12. **`java.util.concurrent`** 包:提供了线程安全的数据结构和并发工具类,如`ConcurrentHashMap`, `ExecutorService`, `Future`, `Semaphore`等,用于高效地进行多线程编程。 13. **`java.util.stream.Stream`*...

    使用java.util.Timer实现任务调度

    Java.util.Timer 是 Java 平台中用于实现定时任务调度的一个工具类。...在更复杂的场景下,可以考虑使用 `java.util.concurrent.ScheduledExecutorService`,它提供了更强大且线程安全的任务调度能力。

    JUC-High-Concurrency:java.util.concurrent JUC高并发处理

    Java.util.concurrent(JUC)是Java平台中处理高并发的核心工具包,它为开发者提供了丰富的并发组件和机制,使得在多线程环境下的编程变得更加高效和安全。本篇将深入探讨JUC中的重要知识点,包括同步、可重入锁、类...

    java API 1.8

    在多线程编程上,`Fork/Join`框架被引入,通过`java.util.concurrent.ForkJoinPool`和`java.util.concurrent.RecursiveTask`,开发者可以编写高效、可并行执行的任务,特别适合处理大量数据的分割和合并问题。...

    java随机数

    如果需要更复杂的功能或在并发环境下工作,则应考虑使用 `java.util.Random` 或 `java.util.concurrent.ThreadLocalRandom`。理解这些方法的差异可以帮助开发者选择最合适的技术方案,以满足具体项目的需求。

    java多线程编程总结

    - `java.util.concurrent.locks`包提供了多种类型的锁,如`ReentrantLock`等。 ##### 4. 信号量 - `java.util.concurrent.Semaphore`用于控制对有限资源的访问。 ##### 5. 阻塞队列 - `java.util.concurrent....

    JavaAPI文档中文版

    4. **多线程编程**:Java API支持多线程编程,`java.lang.Thread`和`java.util.concurrent`包提供了创建、管理和同步线程的工具。`java.util.concurrent`包引入了许多高级并发工具,如ExecutorService、Semaphore、...

    JAVA API文档

    3. **多线程编程**:Java API中的`java.lang.Thread`和`java.util.concurrent`包提供了多线程编程的支持。`Thread`类代表一个可执行的线程,而`java.util.concurrent`包则包含高级并发工具,如ExecutorService、...

Global site tag (gtag.js) - Google Analytics