Runnbale封装一个异步运行的任务,可以把它想象成一个没有任何参数和返回值的异步方法。Callable和Runnable相似,但是它有返回值。Callable接口是参数化的类型,只有一个方法call

public interface Callable<V> {

    V call() throws Exception;

}

类型参数就是返回值的类型,例如:Callable<String>表示最终返回一个String的异步操作(计算)

Runnbale封装一个异步运行的任务,可以把它想象成一个没有任何参数和返回值的异步方法。Callable和Runnable相似,但是它有返回值。Callable接口是参数化的类型,只有一个方法call()

public interface Callable<V> {

    V call() throws Exception;

}

类型参数就是返回值的类型,例如:Callable<String>表示最终返回一个String的异步操作(计算)

  1. //求素数 
  2. class PrimeCallable implements Callable<int[]> { 
  3.     private int max; 
  4.      
  5.     public PrimeCallable(int max) { 
  6.         this.max = max; 
  7.     } 
  8.      
  9.     @Override 
  10.     public int[] call() throws Exception { 
  11.         List<Integer> result = new ArrayList<Integer>(); 
  12.         for(int i = 2; i <= max; i++) { 
  13.             System.out.println("System is checking data " + i); 
  14.             if(isPrime(i)) { 
  15.                 result.add(i); 
  16.             } 
  17.         } 
  18.          
  19.         Integer[] iters = result.toArray(new Integer[]{}); 
  20.         int[] array = new int[iters.length]; 
  21.         int i = 0
  22.         for(Integer iter : iters) { 
  23.             array[i++] = iter; 
  24.         } 
  25.         return array; 
  26.     } 
  27.      
  28.     private boolean isPrime(int data) { 
  29.         try { 
  30.             Thread.sleep(5); 
  31.         } catch (InterruptedException e) { 
  32.             e.printStackTrace(); 
  33.         } 
  34.         for(int i = 2; i < ((int)Math.sqrt(data)+1); i++) { 
  35.             if(data % i == 0)  
  36.                 return false
  37.         } 
  38.         return true
  39.     } 

  1. Callable<int[]> primeCallable = new PrimeCallable(1000); 
  2.         FutureTask<int[]> ftask = new FutureTask<int[]>(primeCallable); 
  3.          
  4.         Thread t = new Thread(ftask); 
  5.         t.start(); 
  6.          
  7.         int[] result = null
  8.         System.out.println("Waiting for result....."); 
  9.         try { 
  10.             result = ftask.get(); 
  11.         } catch (InterruptedException e) { 
  12.             e.printStackTrace(); 
  13.         } catch (ExecutionException e) { 
  14.             e.printStackTrace(); 
  15.         } 
  16.          
  17.         for(int i = 0; result != null && i < result.length; i++) { 
  18.             if(i != 0 && i % 10 == 0) { 
  19.                 System.out.println(); 
  20.             } 
  21.             System.out.print(String.format("%1$-5s", result[i])); 
  22.         } 

  1. 执行结果: 
  2. Waiting for result..... 
  3. System is checking data 2 
  4. System is checking data 3 
  5. System is checking data 4 
  6. System is checking data 5 
  7. System is checking data 6 
  8. System is checking data 7 
  9. .................................. 
  10. System is checking data 999 
  11. System is checking data 1000 
  12. 2    3    5    7    11   13   17   19   23   29    
  13. 31   37   41   43   47   53   59   61   67   71    
  14. 73   79   83   89   97   101  103  107  109  113   
  15. 127  131  137  139  149  151  157  163  167  173   
  16. 179  181  191  193  197  199  211  223  227  229   
  17. 233  239  241  251  257  263  269  271  277  281   
  18. 283  293  307  311  313  317  331  337  347  349   
  19. 353  359  367  373  379  383  389  397  401  409   
  20. 419  421  431  433  439  443  449  457  461  463   
  21. 467  479  487  491  499  503  509  521  523  541   
  22. 547  557  563  569  571  577  587  593  599  601   
  23. 607  613  617  619  631  641  643  647  653  659   
  24. 661  673  677  683  691  701  709  719  727  733   
  25. 739  743  751  757  761  769  773  787  797  809   
  26. 811  821  823  827  829  839  853  857  859  863   
  27. 877  881  883  887  907  911  919  929  937  941   
  28. 947  953  967  971  977  983  991  997