使用jdk8有一段时间了,经常到stream和lambda操作集合,项目一般也都使用的是spring framework系列。借助lambda可以实现类似 python 闭包的写法,传递代码块给方法,异步方法加让lambda就可以实现任意代码块的异步执行。
首先定一个接口用来执行异步代码块
public interface AsyncService { void asyncInvoke(AsyncExec consumer) throws WxErrorException; @FunctionalInterface interface AsyncExec { void exec() throws WxErrorException; } }
给一个实现并交给spring容器管理
@Service public class AsyncServiceImpl implements AsyncService { @Async @Override public void asyncInvoke(AsyncExec asyncExec) throws WxErrorException { asyncExec.exec(); } }
简单测试一下
@RunWith(SpringRunner.class) @SpringBootTest(webEnvironment = SpringBootTest.WebEnvironment.RANDOM_PORT) @ActiveProfiles("dev") @Slf4j public class AsyncServiceTest { @Autowired private AsyncService asyncService; @Test public void asyncServiceTest() throws WxErrorException, InterruptedException { log.info("111111111111111"); asyncService.asyncInvoke(() -> { try { Thread.sleep(1000); log.info("异步方法执行"); } catch (InterruptedException e) { e.printStackTrace(); } }); log.info("222222222222222"); Thread.sleep(2000); } }
测试结果
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网
猜你喜欢:- iphone – 异步函数执行?
- JavaScript 同步和异步(执行机制)
- Netty推荐addListener回调异步执行
- Promise面试题2实现异步串行执行
- Golang 异步任务执行器——Gochan
- [Java并发-16] CompletionService:批量执行异步任务
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。