如今的系统基本都是分布式的,各个系统各司其职的,不可能一个系统干了全部系统的事。

所以系统之间的交互就越来越多了。那么系统之间的交互仅仅有通过网络来交互了,而网络必定会存在延时的情况。

比方A系统的一个功能要实现,当中某一步要去B系统拿一个全局唯一的ID值,那么此时在A系统的功能实现中就会发生对B系统的调用。假设是同步调用的话,可能会影响性能

String id = httpToB(url);

这样写的话,就是传统的同步方式,会一直等待B系统给出响应后才会继续往下运行。可是现实中。可能不是这种。由于时间可能非常长。所以先来一个线程去B系统拿这个ID值。当前线程,继续像后运行,当运行到某一步须要用到这个ID值了,再来取

这时候,就能够通过Future或者FutureTask来实现了。Future是接口,FutureTask是Future的一个详细实现类

private static ThreadPoolExecutor poolExe = new ThreadPoolExecutor(100, 1000, 1,
TimeUnit.SECONDS, new LinkedBlockingDeque<Runnable>(100)); private static Future<String> getUamKid() {
return poolExe.submit(new Callable<String>() {
public String call() throws Exception {
// TODO Auto-generated method stub
return sendHttpPostRequest("XXXXXXXXX", "");
} });
} public static void main(String a[]) throws Exception {
Future<String> future = getUamKid();
System.out.println("去B系统取ID,如今我能够做自己的事情了");
System.out.println("ID拿到了吗?" + future.isDone());
long counter = 0;
String uamKid = "";
while (!future.isDone()) {
counter++;
//System.out.println("我等。我等。我等等等...");
}
uamKid = future.get();
System.out.println("ID = " + uamKid);
System.out.println("进去等了多少次?" + counter);
}
去B系统取ID,如今我能够做自己的事情了
ID拿到了吗?false
ID = 38176732481585156
进去等了多少次?4318049299

前面无数个等等等...

能够看到了,等了4318049299这么多次,说明while循环了4318049299次才完毕啊。

使用FutureTask的话,几乎相同。參照:http://blog.csdn.net/simonchi/article/details/8181571

【JAVA】java中Future、FutureTask的使用的更多相关文章

  1. Java 并发:Future FutureTask

    Future 当向一个ExecutorService提交任务后可以获得一个Future对象,在该对象上可以调用get,cancel等命令来获取任务运行值或者是取消任务.下面是一个简单的计数任务: pu ...

  2. paip.java 多线程参数以及返回值Future FutureTask 的使用.

    paip.java 多线程参数以及返回值Future FutureTask 的使用. 在并发编程时,一般使用runnable,然后扔给线程池完事,这种情况下不需要线程的结果. 所以run的返回值是vo ...

  3. Java 并发编程——Callable+Future+FutureTask

    Java 并发编程系列文章 Java 并发基础——线程安全性 Java 并发编程——Callable+Future+FutureTask java 并发编程——Thread 源码重新学习 java并发 ...

  4. Java 线程池Future和FutureTask

    Future表示一个任务的周期,并提供了相应的方法来判断是否已经完成或者取消,以及获取任务的结果和取消任务. Future接口源码: public interface Future<V> ...

  5. java中Future的使用

    文章目录 创建Future 从Future获取结果 取消Future 多线程环境中运行 java中Future的使用 Future是java 1.5引入的一个interface,可以方便的用于异步结果 ...

  6. Java中设置方法执行的超时时间java.util.concurrent.Future

    java.util.concurrent.Future Future代表一个异步计算的结果.它提供了方法来检查是否计算已经完成,还是正在计算而处于等待状态,并且也提供了获取计算结果 方法.当计算完成后 ...

  7. java并发之Future与Callable使用

    java并发之Future与Callable使用 这篇文章需要大家知道线程.线程池的知识,尤其是线程池. 有的时候我们要获取线程的执行结果,这个时候就需要用到Callable.Future.Futur ...

  8. Java异步调用Future对象

    Future类存在于JDK的concurrent包中,主要用途是接收Java的异步线程计算返回的结果. 个人理解的使用场景大概如下: 有两个任务A和B,A任务中仅仅需要使用B任务计算成果,有两种方法实 ...

  9. 在Java 线程中返回值的用法

    http://icgemu.iteye.com/blog/467848 在Java 线程中返回值的用法 博客分类: Java Javathread  有时在执行线程中需要在线程中返回一个值:常规中我们 ...

  10. Java 多线程中的任务分解机制-ForkJoinPool,以及CompletableFuture

    ForkJoinPool的优势在于,可以充分利用多cpu,多核cpu的优势,把一个任务拆分成多个“小任务”,把多个“小任务”放到多个处理器核心上并行执行:当多个“小任务”执行完成之后,再将这些执行结果 ...

随机推荐

  1. CQOI2018 九连环 打表找规律 fft快速傅里叶变换

    题面: CQOI2018九连环 分析: 个人认为这道题没有什么价值,纯粹是为了考算法而考算法. 对于小数据我们可以直接爆搜打表,打表出来我们可以观察规律. f[1~10]: 1 2 5 10 21 4 ...

  2. 解决Spellchecker inspection helps locate typos and misspelling in your code

    idea出现这个是因为词库中没有这个单词,所以提示拼写错误 解决办法:双击下面有虚线的单词——>鼠标右键——>spelling——>save 'xxx' to distionary

  3. curl 模拟post请求

    curl -H "Content-Type:application/json" -X POST --data '{"openId":"xxxxxxx& ...

  4. memcached 的内存管理与删除机制

    1:内存的碎片化 如果用 c 语言直接 malloc,free 来向操作系统申请和释放内存时, 在不断的申请和释放过程中,形成了一些很小的内存片断,无法再利用. 这种空闲,但无法利用内存的现象,--- ...

  5. 宝塔nginx配置

    虚拟机配置 server { listen 80; server_name mayibang.co *.mayibang.co; index index.php index.html index.ht ...

  6. Django框架基础知识11-会话状态保持及表单

    浏览器存储cookie的方式不太安全,那有没有更好些的来存储登入状态的方式呢??? 状态保持----cookie和session: 状态保持: 1.http协议是无状态的:每次请求都是一次新的请求,不 ...

  7. 【UVA 10820】Send a Table(欧拉函数)

    Description When participating in programming contests, you sometimes face the following problem: Yo ...

  8. 计蒜客 Overlapping Rectangles (离散化)

    题意: 给定一个坐标系, 给出n个矩形的左下角坐标(bx,by)和右上角坐标(tx,ty) , 求矩形覆盖的面积, 有些区域会被多个矩形覆盖, 但只用算一次. n <= 1000,  0 < ...

  9. 一份快速实用的 tcpdump 命令参考手册

    对于 tcpdump 的使用,大部分管理员会分成两类.有一类管理员,他们熟知  tcpdump 和其中的所有标记:另一类管理员,他们仅了解基本的使用方法,剩下事情都要借助参考手册才能完成.出现这种情况 ...

  10. Apache手册

    一.apache的安装 如果不指定安装位置,默认为/usr/local/apache2/