线程池 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("消息发送失败");
	   }
   }

}

  

总结:对线程基础知识的理解不是很清楚导致的,看来以后还得要多加思考和练习才行。

posted on 2021-06-24 08:36  ~码铃薯~  阅读(267)  评论(0编辑  收藏  举报

导航