主题:java.util.concurrent包开发实例
来源:互联网 发布:js取小数点前面的数字 编辑:程序博客网 时间:2024/05/08 06:57
从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对象做操作,即可以控制程序的执行顺序。
最后写一些想法:其实并发程序在很多时候能够极大地加快执行的效率,现在比较流行的多机器联合工作,其实完全可以用这套并行机制来实现。分服务器和任务机,服务器负责分解任务,任务机负责执行任务并返回结果,服务器负责收集结果并且整合。对于简单模型的可拆解任务,完全可以实现。对于复杂的如:多个结果间具有顺序关系,结果相互影响等就比较麻烦。
- 主题:java.util.concurrent包开发实例
- java.util.concurrent包
- java.util.concurrent包
- java.util.concurrent包
- java.util.concurrent包
- concurrent包:java.util.concurrent.atomic
- java.util.concurrent包探秘
- Java.Util.concurrent包学习
- java.util.concurrent.locks包
- java.util.concurrent.Semaphore 实例
- java并发包java.util.concurrent
- java.util.concurrent包分类结构图
- 使用java.util.concurrent包处理多线程
- java.util.concurrent包之Lock
- java.util.concurrent包API学习笔记
- java.util.concurrent.atomic 类包详解
- java.util.concurrent包API学习笔记
- java.util.concurrent并发包一览
- 用c编写求信息论中各种熵和信息量的程序
- 关于v$db_object_cache的一些脚本
- 动态增加表格行
- 大家好啊
- 科普推荐
- 主题:java.util.concurrent包开发实例
- mysql 乱码处理
- 关于gethostbyname和getaddrinfo的一个问题
- 《英雄》张艺谋
- 转Hibernate3.0
- Gauss平滑
- 关于msn9安装不上的问题
- zoj 1101 Gamblers 跳多重循环!!
- 性能管理