使用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:批量执行异步任务
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。