多线程Callable实现并发访问接口实例
Runnable是执行工作的独立任务,但是它不返回任何值和抛出异常。在Java SE5中引入的Callable是一种具有类型参数的泛型,它的类型参数表的是从方法call()中返回的值,还可以抛出异常并且必须使用ExecutorServices.submit()方法调用它,下面是一个简单示例用来并发请求接口执行 并且返回结果add到result结果然后遍历输出打印结果.get()。
/**
* 多线程并发测试提交订单
*/
@Test
public void subOrderWithCallable() {
ExecutorService exec = Executors.newCachedThreadPool();
List<Future<ApiResult>> results =new ArrayList<>();
List<Map<String, String>> list=new ArrayList<>();
Map<String, String> params = new HashMap<>();
params.put("userName", "ceshi");
params.put("mobile", "150****3024");
params.put("flowSize", "10");
params.put("type", "3");
list.add(params);
Map<String, String> params1 = new HashMap<>();
params1.put("userName", "ceshi");
params1.put("mobile", "132****0588");
params1.put("flowSize", "20");
params1.put("type", "0");
list.add(params1);
Map<String, String> params2 = new HashMap<>();
params2.put("userName", "ceshi");
params2.put("mobile", "189****1946");
params2.put("flowSize", "5");
params2.put("type", "3");
list.add(params2);
//同时三个数据访问同一个接口
for (int i = 0; i < list.size(); i++) {
Map<String, String> stringStringMap = list.get(i);
results.add(exec.submit(new TaskWithResult(flowSupService.submitOrder(stringStringMap))));
}
for (Future<ApiResult> fs : results) {
try {
System.out.println(fs.get());
} catch (InterruptedException e) {
e.printStackTrace();
} catch (ExecutionException e) {
e.printStackTrace();
}
}
}
}
class TaskWithResult implements Callable<ApiResult> {
ApiResult apiResult=new ApiResult();
public TaskWithResult(ApiResult apiResult) {
this.apiResult = apiResult;
}
@Override
public ApiResult call() throws Exception {
return apiResult;
}
}
请说明转载地址 :http://blog.csdn.net/qq_36565494/article/details/78739215