Callable是jdk提供的多线程工具类
来自 java.util.concurrent.Callable;
Callable的使用方式比较简单,对于一般的多线程使用Callable接口就可以完成。
DeferredResult是由spring提供的一个多线程工具类,使用比较复杂,但是能做的事情更多
来自 org.springframework.web.context.request.async.DeferredResult
Callable的使用案例,需要重写call方法。处理完业务后将结果返回
使用了slf4j日志,下面试maven的依赖,加入依赖后就可以使用了
<!-- https://mvnrepository.com/artifact/org.slf4j/slf4j-api -->
<dependency>
<groupId>org.slf4j</groupId>
<artifactId>slf4j-api</artifactId>
<version>1.7.30</version>
</dependency>
来自仓库:https://mvnrepository.com/artifact/org.slf4j/slf4j-api/1.7.30package top.huashengshu.springsecuritydemoimooc.controller; import org.slf4j.Logger; import org.slf4j.LoggerFactory; import org.springframework.web.bind.annotation.GetMapping; import org.springframework.web.bind.annotation.ResponseBody; import org.springframework.web.bind.annotation.RestController; import java.util.concurrent.Callable; @RestController public class UserController { private Logger logger= LoggerFactory.getLogger(getClass()); @GetMapping("/orderNumber")//获取订单号 @ResponseBody public Callable<String > test() { //tomcat处理请求 logger.info("tomcat处理请求"); Callable <String> result=new Callable<String>() { @Override public String call() throws Exception { //业务逻辑 logger.info("处理业务"); Thread.sleep(1000);//暂停1s模拟处理业务 //业务处理完成返回结果 logger.info("业务处理完成"); return "success"; } }; //处理完成 logger.info("tomcat处理完成"); return result; } }
仔细看下标出来的内容,和注释处理的信息
会发现对于tomcat服务器来说几乎在接受到请求后就处理完成了,而真正的任务交给了副线程。同时该线程空闲出来,也就是或该 tomcat线程就可以处理另外的客户端请求。提高了吞吐量。
DeferredResult案例