zoukankan      html  css  js  c++  java
  • 线程池 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("消息发送失败");
    	   }
       }
    
    }
    

      

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

  • 相关阅读:
    [算法]外部排序
    [笔试]华为编程大赛题目
    [C++]字符串处理方法(STL与C风格)
    如何动态建立VFP能够打开的中文字段 dbf 表 北极星
    使用 VCL BDE 组件动态创建数据库表 北极星
    如何用Table控件判断数据库是否为空 北极星
    DNGuard HVM副产品(元数据名称编辑器)
    常见dotNet加密保护工具分析介绍
    DNGuard HVM 试用版 RC1 发布
    [转载]Modifying IL at runtime
  • 原文地址:https://www.cnblogs.com/dongyaotou/p/14925278.html
Copyright © 2011-2022 走看看