1、Callable
Callable的异步实现,需要主线程调用副线程来实现
import java.util.concurrent.Callable;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
@RestController
public class AsyncController {
private Logger logger = LoggerFactory.getLogger(getClass());
@RequestMapping("/callableOrder")
public Callable<String> callableOrder() {
logger.info("主线程开始");
//创建新线程,在主线程中调用
Callable<String> callable = new Callable<String>() {
@Override
public String call() throws Exception {
logger.info("副线程开始");
Thread.sleep(3000);
logger.info("副线程结束");
return "success";
}
};
logger.info("主线程结束");
return callable;
}
}
测试结果:
2019-05-16 21:55:00.688 INFO 5716 --- [nio-8080-exec-1] com.llangzh.controller.AsyncController : 主线程开始
2019-05-16 21:55:00.690 INFO 5716 --- [nio-8080-exec-1] com.llangzh.controller.AsyncController : 主线程结束
2019-05-16 21:55:00.702 INFO 5716 --- [ MvcAsync1] com.llangzh.controller.AsyncController : 副线程开始
2019-05-16 21:55:03.704