Java 多執行緒處理任務的封裝
最近公司專案很多地方使用多執行緒處理一些任務,邏輯程式碼和java多執行緒處理程式碼混合在一起,造成程式碼的可讀性超級差,現在把Java多執行緒相關的處理抽出來,方面程式碼中重複使用。抽的不好,歡迎大家拍磚
使用方法很簡單,有兩種使用方法
1.直接傳遞一批任務給到多執行緒處理方法,返回處理結果
程式碼如下:
/** * Created with IntelliJ IDEA. * 測試多執行緒處理任務 * className: TaskMulThreadServiceTest * * @version 1.0 * Date Time: a *@author: ddys */ public class TaskMulThreadServiceTest extends TestCase implements ITaskHandle<String,Boolean>{ public void testExecute() throws Exception { String [] taskItems = new String[100]; for (int i=0;i<100;i++){ taskItems[i]="任務"+i; } IMulThreadService<String,Boolean> mulThreadService = new TaskMulThreadService(this); long start = System.currentTimeMillis(); List<Boolean> result = mulThreadService.execute(taskItems); for (Boolean e : result){ if(!e){ System.out.println("任務處理失敗"); } } System.out.println("所有任務處理完成,耗時"+(System.currentTimeMillis()-start)+",任務成功數"+result.size()); } /** * Created with IntelliJ IDEA. * 執行任務,返回所有執行的結果 * className: TaskMulThreadService * * @author: ddys * @version 1.0 * Date Time: */ public Boolean execute(String s) { System.out.println(Thread.currentThread().getId()+"執行緒正在處理"+s); return true; } }
2.附帶一個查詢任務的方法,實現這個查詢任務方法和業務處理方法,然後執行返回處理結果
程式碼如下:
ate Time: a *@author: XWK */ public class SelectTaskMulThreadServiceTest extends TestCase implements ISelectTask<String,Boolean>{ public void testExecute() throws Exception { IMulThreadService<String,Boolean> mulThreadService = new SelectTaskMulThreadService(this); long start = System.currentTimeMillis(); List<Boolean> result = mulThreadService.execute(); for (Boolean e : result){ if(!e){ System.out.println("任務處理失敗"); } } System.out.println("所有任務處理完成,耗時"+(System.currentTimeMillis()-start)+",任務成功數"+result.size()); } /** * Created with IntelliJ IDEA. * 執行任務,返回所有執行的結果 * className: TaskMulThreadService * * @author: ddys * @version 1.0 * Date Time: */ public Boolean execute(String s) { System.out.println(Thread.currentThread().getId()+"執行緒正在處理"+s); return true; } /** * @param 'a 傳遞引數 * @return a 回型別 * @throws * @Title: a * @Description: 獲取一批任務 * @author ddys * @date 2015-11-15 21:09 */ public String[] getTaskItem() { String [] taskItems = new String[100]; for (int i=0;i<100;i++){ taskItems[i]="任務"+i; } return taskItems; } }
相關文章
- Java多執行緒並行處理任務的實現Java執行緒並行
- Java多執行緒——獲取多個執行緒任務執行完的時間Java執行緒
- Spring多執行緒事務處理Spring執行緒
- java中多執行緒併發的處理方式Java執行緒
- 畫江湖之 PHP 多執行緒開發 【利用多執行緒 序列任務變並行處理 從而減少序列執行時間】PHP執行緒並行
- 批量任務體現多執行緒的威力!執行緒
- 多執行緒程式設計,處理多執行緒的併發問題(執行緒池)執行緒程式設計
- .net使用Task多執行緒執行任務 .net限制執行緒數量執行緒
- JAVA多執行緒下高併發的處理經驗Java執行緒
- java 基礎之圖片的多執行緒處理和大檔案的多執行緒拷貝Java執行緒
- 使用 Rx 的計算和最大化執行緒處理並行任務執行緒並行
- Java多執行緒事務管理Java執行緒
- Swift多執行緒:使用Thread進行多執行緒間通訊,協調子執行緒任務Swift執行緒thread
- java多執行緒:執行緒體往外丟擲異常的處理機制實踐Java執行緒
- 多工處理方式之二:多執行緒執行緒
- Java多執行緒——執行緒Java執行緒
- C#多執行緒(13):任務基礎①C#執行緒
- C#多執行緒(14):任務基礎②C#執行緒
- C#多執行緒(15):任務基礎③C#執行緒
- Spring Boot使用執行緒池處理事務任務Spring Boot執行緒
- Java多執行緒之synchronized理論Java執行緒synchronized
- 【轉】JAVA處理執行緒超時Java執行緒
- 前端多執行緒處理——async/await前端執行緒AI
- PHP 多程式處理任務PHP
- Java多執行緒-執行緒中止Java執行緒
- Java多執行緒——執行緒池Java執行緒
- Java多執行緒-執行緒池的使用Java執行緒
- 【Java多執行緒】執行緒安全的集合Java執行緒
- Python實現投遞多執行緒任務Python執行緒
- Spring Task 定時任務 - 多執行緒配置Spring執行緒
- 死磕 java執行緒系列之執行緒池深入解析——普通任務執行流程Java執行緒
- Android 效能優化之使用執行緒池處理非同步任務Android優化執行緒非同步
- 【Java多執行緒】輕鬆搞定Java多執行緒(二)Java執行緒
- C#多執行緒開發-任務並行庫04C#執行緒並行
- 多執行緒-定時任務的多次執行程式碼體現執行緒行程
- java——多執行緒Java執行緒
- java 多執行緒Java執行緒
- 【Java】多執行緒Java執行緒