最近在开发的过程中有使用到线程池,使用的场景是这样的,因为发送的消息的量已经达到千万级别了,这个时候就只能使用线程池了。
但是遇到了一个问题,就是在主方法的里面调用异步的方法的时候,返回值总是接收不到,发送不成功的假象,但是在postman中确实是能够发送成功的。
以下是自己写的错误的代码:
@Component public class MainInfo{ @Autowired private AsyncInfoTask asyncInfoTask; @KafkaListener(topic="监听主题") public void mainMethod(){ //主业务代码 //异步方法调用 Object object=asyncInfoTask.sendMessage(info); if(null!=object){ sout("消息发送成功"); }else{ sout("消息发送失败"); } } }
@Component public class AsyncInfoTask{ @async("线程池实例") public Object sendMessage(String info){ //省略httpclient其他传参步骤 Object object=httpclient.submit(info); return object; } }
这样写看起来是没有什么问题的。但是其实犯了一个很低级的错误,我们项目中使用的创建线程的方式是没有返回值的哪一种,而线程要想有返回值的话得用实现Callable接口的这种方式才行。
我说怎么搞的,一直发送失败。
明白了错误产生的原因,那就改代码呗!
以下是自己改正之后的代码:
@Component public class MainInfo{ @Autowired private AsyncInfoTask asyncInfoTask; @KafkaListener(topic="监听主题") public void mainMethod(){ //主业务代码 //异步方法调用 asyncInfoTask.sendMessage(info); } }
@Component public class AsyncInfoTask{ @async("线程池实例") public void sendMessage(String info){ //省略httpclient其他传参步骤 Object object=httpclient.submit(info); if(null!=object){ sout("消息发送成功"); }else{ sout("消息发送失败"); } } }
总结:对线程基础知识的理解不是很清楚导致的,看来以后还得要多加思考和练习才行。