构建高性能工作线程 四 具体应用

本文探讨了并发处理中的核心概念,通过实现一个自定义的线程池类,展示了如何高效地处理任务并利用缓冲队列进行结果的传递与管理。通过定时任务的触发,实现了任务的定期执行与结果的收集。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

继承工作线程的具体任务线程

public class BeenCoverThread extends WorkThread {

    //缓冲队列,任务线程处理完结果放入到缓冲队列
    private LinkedBlockingQueue beenCoverQueue;

    //taskExecutor 线程池出入线程进行监控
   //beenCoverQueue 传入缓冲队列
   public BeenCoverThread (CallInfo callInfo,TaskExecutor taskExecutor, LinkedBlockingQueue beenCoverQueue) {
      super(taskExecutor);
      this.beenCoverQueue= beenCoverQueue;
   }

    //实现父类,具体做的任务在此完成,一些很耗时的操作放入此处完成
    public void doTask() throws Exception {
        。。。。
      beenCoverQueue.offer(beenInfo);//处理结果放入缓冲队列
     。。。。
   }

}

 
定时任务进行定期启动任务

public class QueryCallTask {
     //缓冲队列
     private static LinkedBlockingQueue beenCoverQueue = new LinkedBlockingQueue<BeenCoverInfo>();
    
     //已经在配置的  扩展spring后的线程池
     private TaskExecutor beenCoverExecutor;

     // 定时任务 执行方法   
     public void execute() {
          .......
           beforeExcute();//进入线程前进行全局缓冲区一些操作
          .......
           for (int i = 0; i < callList.size(); i++) {
                 CallInfo callInfo = callList.get(i);
                 beenCoverExecutor.execute(new BeenCoverThread(
                       callInfo,beenCoverExecutor,beenCoverQueue)
           }
          .......
     }
     
     private void beforeExcute(){
        。。。
     final LinkedBlockingQueue beenCoverQueue2 = new LinkedBlockingQueue(beenCoverQueue);//复制到新缓冲
       beenCoverQueue.clear();//清空全局缓冲
       .....
       cationDao.batchUpdate(beenCoverQueue2 );//主线程操作新缓冲
     。。。

    }
}

 


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值