线程池 async-service-, 2. do submit,taskCount [3], completedTaskCount [3], activeCount [0], queueSize [0]
最近在开发的过程中有使用到线程池,使用的场景是这样的,因为发送的消息的量已经达到千万级别了,这个时候就只能使用线程池了。
但是遇到了一个问题,就是在主方法的里面调用异步的方法的时候,返回值总是接收不到,发送不成功的假象,但是在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("消息发送失败");
}
}
}
总结:对线程基础知识的理解不是很清楚导致的,看来以后还得要多加思考和练习才行。
浙公网安备 33010602011771号