1. 程式人生 > >帶返回值的多執行緒

帶返回值的多執行緒

參考地址:http://blog.51cto.com/lavasoft/222082

為了提高執行效率,有時可以採用多執行緒執行

1、每個執行緒執行的方法一樣

import java.util.concurrent.*; 

/** 
* Java執行緒:有返回值的執行緒 
* 
* @author Administrator 2009-11-5 0:41:50 
*/ 
public class Test { 
        public static void main(String[] args) throws ExecutionException, InterruptedException { 
                
//建立一個執行緒池 ExecutorService pool = Executors.newFixedThreadPool(2); //建立兩個有返回值的任務 Callable c1 = new MyCallable("A"); Callable c2 = new MyCallable("B"); //執行任務並獲取Future物件 Future f1 = pool.submit(c1); Future f2
= pool.submit(c2); //從Future物件上獲取任務的返回值,並輸出到控制檯 System.out.println(">>>"+f1.get().toString()); System.out.println(">>>"+f2.get().toString()); //關閉執行緒池 pool.shutdown(); } } class MyCallable implements
Callable{ private String oid; MyCallable(String oid) { this.oid = oid; } @Override public Object call() throws Exception { //具體執行的程式碼 return oid+"任務返回的內容"; } }

2、每個執行緒執行的任務不一樣

import java.util.concurrent.*; 

/** 
* Java執行緒:有返回值的執行緒 
* 
* @author Administrator 2009-11-5 0:41:50 
*/ 
public class Test { 
        public static void main(String[] args) throws ExecutionException, InterruptedException { 
                //建立一個執行緒池 
                ExecutorService pool = Executors.newFixedThreadPool(2); 
                //建立兩個有返回值的任務 
               // 查詢最新的結果
        Callable<JSONObject> c1 = new Callable<JSONObject>() {
            @Override
            public JSONObject call() throws Exception {
                JSONObject jsonObject = new JSONObject();
                jsonObject.put("orgId", _orgId);
                JSONObject queryStr = 
                                HttpHelper.SINGLON.query("findOrgDataitem", jsonObject);
                return queryStr;
            }
        };
               // 查詢歷史版本結果
        Callable<JSONObject> c2= new Callable<JSONObject>() {
            @Override
            public JSONObject call() throws Exception {
                File file = new File(
                          FileCatalog.DATAITEM_HISTORY.getPath(_request, _orgId.toString(), _nearlyVersion, INFO_JSON));
                if (!file.exists()) {
                    return null;
                }
                String read = FileUtils.readFileToString(file, SysConstant.CSN);
                if (StringUtils.isBlank(read)) {
                    return null;
                }
                return new JSONObject(read);
            }
        };
                //執行任務並獲取Future物件 
                Future f1 = pool.submit(c1); 
                Future f2 = pool.submit(c2); 
                //從Future物件上獲取任務的返回值,並輸出到控制檯 
                System.out.println(">>>"+f1.get().toString()); 
                System.out.println(">>>"+f2.get().toString()); 
                //關閉執行緒池 
                pool.shutdown(); 
        } 
} 

要深入瞭解還需要看Callable和Future介面的API。

ps.在xml檔案中配置執行緒池

<!-- 執行緒池配置 -->
    <bean id="threadPool" class="org.springframework.scheduling.concurrent.ThreadPoolTaskExecutor" scope="singleton">
        <!-- 核心執行緒數  -->
        <property name="corePoolSize" value="10" />
        <!-- 最大執行緒數 -->
        <property name="maxPoolSize" value="50" />
        <!-- 佇列最大長度 -->
        <property name="queueCapacity" value="1000" />
        <!-- 執行緒池維護執行緒所允許的空閒時間 -->
        <property name="keepAliveSeconds" value="300" />
        <!-- 執行緒池對拒絕任務(無執行緒可用)的處理策略 -->
        <property name="rejectedExecutionHandler">
            <bean class="java.util.concurrent.ThreadPoolExecutor$CallerRunsPolicy" />
        </property>
    </bean>