帶返回值的多執行緒
阿新 • • 發佈:2018-12-12
參考地址: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 implementsCallable{ 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>