标签:map bService 扇出 add 模块 put 返回值 执行 效率
有一个场景:
正常情况下:在ServiceA中调用ServiceB,ServiceC,ServiceD,将B,C,D的返回结果放入一个对象中。
使用多线程:每一个线程去执行一个方法,但是会有一个问题,将结果存入的时候,有可能没有执行完。
即:
BService bService; CService cService; AServiceImpl{ 返回值1 = bService.add(XX) 返回值2 = cService.add(XX) map.put("key1",返回值1) map.put("key2",返回值2) }
使用了多线程,方法执行时异步的,有可能 map.put("key1",返回值1)执行了,但返回值1 = bService.add(XX)还未执行,这样就获取不到值,就像Ajax一样。
解决:使用实现Callable接口创建线程的方式,因为Callable创建线程,线程执行的时候是异步的,获取结果的时候是同步。
在call()方法里面执行方法
public class MyCallable implements Callable<Object> { @Override public Object call() throws Exception { 返回值1 = bService.add(xx); return 返回值1; } }
AServiceImpl.java
通过get()方法拿值
BService bService; CService cService; AServiceImpl{
返回值1= futureTask.get(); map.put("key1",返回值1);
}
为什么get是同步的但还是增加了效率?
虽然获取结果是同步的,但方法执行的时候是异步的,逻辑方法是同时运行的,不管怎么样比顺序执行要快。
标签:map,bService,扇出,add,模块,put,返回值,执行,效率 来源: https://www.cnblogs.com/fan-King/p/16167465.html
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。