多線程callable使用方法


Runnable是執行工作的獨立任務,但是它不返回任何值。在Java SE5中引入的Callable是一種具有類型參數的泛型,它的類型參數表的是從方法call()中返回的值,並且必須使用ExecutorServices.submit()方法調用它,下面是一個簡單示例。

 

package com.test;  
2.  
3.import java.util.ArrayList;  
4.import java.util.List;  
5.import java.util.concurrent.Callable;  
6.import java.util.concurrent.ExecutionException;  
7.import java.util.concurrent.ExecutorService;  
8.import java.util.concurrent.Executors;  
9.import java.util.concurrent.Future;  
10.  
11.public class CallableTest {  
12.    public static void main(String[] args) {  
13.        ExecutorService exec=Executors.newCachedThreadPool();  
14.        List<Future<String>> results=new ArrayList<Future<String>>();  
15.          
16.        for(int i=0;i<5;i++) {  
17.            results.add(exec.submit(new TaskWithResult(i)));  
18.        }  
19.          
20.        for(Future<String> fs :results) {  
21.            try {  
22.                System.out.println(fs.get());  
23.            } catch (InterruptedException e) {  
24.                e.printStackTrace();  
25.            } catch (ExecutionException e) {  
26.                e.printStackTrace();  
27.            }  
28.        }  
29.    }  
30.}  
31.  
32.class TaskWithResult implements Callable<String> {  
33.    private int id;  
34.    public TaskWithResult(int id) {  
35.        this.id=id;  
36.    }  
37.      
38.    @Override  
39.    public String call() throws Exception {  
40.        return "result of TaskWithResult "+id;  
41.    }  
42.}  
package com.test;

import java.util.ArrayList;
import java.util.List;
import java.util.concurrent.Callable;
import java.util.concurrent.ExecutionException;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
import java.util.concurrent.Future;

public class CallableTest {
    public static void main(String[] args) {
        ExecutorService exec=Executors.newCachedThreadPool();
        List<Future<String>> results=new ArrayList<Future<String>>();
        
        for(int i=0;i<5;i++) {
            results.add(exec.submit(new TaskWithResult(i)));
        }
        
        for(Future<String> fs :results) {
            try {
                System.out.println(fs.get());
            } catch (InterruptedException e) {
                e.printStackTrace();
            } catch (ExecutionException e) {
                e.printStackTrace();
            }
        }
    }
}

class TaskWithResult implements Callable<String> {
    private int id;
    public TaskWithResult(int id) {
        this.id=id;
    }
    
    @Override
    public String call() throws Exception {
        return "result of TaskWithResult "+id;
    }
}

 

實驗結果:

 

result of TaskWithResult 0 result of TaskWithResult 1 result of TaskWithResult 2 result of TaskWithResult 3 result of TaskWithResult 4

submit()方法回產生Future對象,它用Callable返回結果的特定類型進行了參數化。可以用isDone()方法來查詢Future是否已經完成,當任務完成時,它具有一個結果,可以調用get()方法獲取該結果。也可以不用isDone()進行檢查就直接調用get(),在這種情況下,get()將阻塞,直至結果准備就緒。還可以在試圖調用get()來獲取結果之前,先調用具有超時的get(),或者調用isDone()來查看任務是否完成。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM