FutureTask获取线程返回值, 用来获取耗时较长的计算结果

下面的例子模拟一个会计算账的过程,主线程已经获得其他帐户的总额了,为了不让主线程等待 PrivateAccount类的计算结果的返回而启用新的线程去处理, 并使用 FutureTask对象来监控,这样,主线程还可以继续做其他事情, 最后需要计算总额的时候再尝试去获得privateAccount 的信息。 


  1. package test;  
  2.   
  3. import java.util.Random;  
  4. import java.util.concurrent.Callable;  
  5. import java.util.concurrent.ExecutionException;  
  6. import java.util.concurrent.FutureTask;  
  7.   
  8. /** 
  9.  * 
  10.  * @author Administrator 
  11.  * 
  12.  */  
  13. @SuppressWarnings("all")  
  14. public class FutureTaskDemo {  
  15.     public static void main(String[] args) {  
  16.         // 初始化一个Callable对象和FutureTask对象  
  17.         Callable pAccount = new PrivateAccount();  
  18.         FutureTask futureTask = new FutureTask(pAccount);  
  19.         // 使用futureTask创建一个线程  
  20.         Thread pAccountThread = new Thread(futureTask);  
  21.         System.out.println("futureTask线程现在开始启动,启动时间为:" + System.nanoTime());  
  22.         pAccountThread.start();  
  23.         System.out.println("主线程开始执行其他任务");  
  24.         // 从其他账户获取总金额  
  25.         int totalMoney = new Random().nextInt(100000);  
  26.         System.out.println("现在你在其他账户中的总金额为" + totalMoney);  
  27.         System.out.println("等待私有账户总金额统计完毕...");  
  28.         // 测试后台的计算线程是否完成,如果未完成则等待  
  29.         while (!futureTask.isDone()) {  
  30.             try {  
  31.                 Thread.sleep(500);  
  32.                 System.out.println("私有账户计算未完成继续等待...");  
  33.             } catch (InterruptedException e) {  
  34.                 e.printStackTrace();  
  35.             }  
  36.         }  
  37.         System.out.println("futureTask线程计算完毕,此时时间为" + System.nanoTime());  
  38.         Integer privateAccountMoney = null;  
  39.         try {  
  40.             privateAccountMoney = (Integer) futureTask.get();  
  41.         } catch (InterruptedException e) {  
  42.             e.printStackTrace();  
  43.         } catch (ExecutionException e) {  
  44.             e.printStackTrace();  
  45.         }  
  46.         System.out.println("您现在的总金额为:" + totalMoney + privateAccountMoney.intValue());  
  47.     }  
  48. }  
  49.   
  50. @SuppressWarnings("all")  
  51. class PrivateAccount implements Callable {  
  52.     Integer totalMoney;  
  53.   
  54.     @Override  
  55.     public Object call() throws Exception {  
  56.         Thread.sleep(5000);  
  57.         totalMoney = new Integer(new Random().nextInt(10000));  
  58.         System.out.println("您当前有" + totalMoney + "在您的私有账户中");  
  59.         return totalMoney;  
  60.     }  
  61.   
  62. }  


运行结果 


  • futureTask线程现在开始启动,启动时间为:3098040622063 
    主线程开始执行其他任务 
    现在你在其他账户中的总金额为56983 
    等待私有账户总金额统计完毕... 
    私有账户计算未完成继续等待... 
    私有账户计算未完成继续等待... 
    私有账户计算未完成继续等待... 
    私有账户计算未完成继续等待... 
    私有账户计算未完成继续等待... 
    私有账户计算未完成继续等待... 
    私有账户计算未完成继续等待... 
    私有账户计算未完成继续等待... 
    私有账户计算未完成继续等待... 
    您当前有3345在您的私有账户中 
    私有账户计算未完成继续等待... 
    futureTask线程计算完毕,此时时间为3103072404138 
    您现在的总金额为:569833345 

你可能感兴趣的:(javaSE,java,线程,FutureTask)