chencg_2013 2016-12-26 09:14 采纳率: 0%
浏览 1330
已结题

Java线程池主动获取任务提升效率是否可行。。

公司这边有一个生产者消费者模型:定时任务每秒从redis取消息,然后交给线程池(ExecutorService)去执行。这个模型在高并发的情况下,必定出现线程池处理不过来的情况,我这边是思路是线程池在执行完一个任务后去检测目前的活跃线程数(this.getActiveCount()),如果活跃数小于最大线程数时,说明线程的任务队列已经为空,则去获取下一批Redis的数据,想问问有没有大神这样做过,安全性和效率方面如何。。

  • 写回答

3条回答

  • oyljerry 2016-12-26 10:50
    关注

    你可以线程池 中的每个线程都是不停的从redis中取消息来工作,如果没有消息,就等待,不需要去判断线程的任务队列是否为空。这样可以提高效率

    评论

报告相同问题?

悬赏问题

  • ¥15 请教:如何用postman调用本地虚拟机区块链接上的合约?
  • ¥15 为什么使用javacv转封装rtsp为rtmp时出现如下问题:[h264 @ 000000004faf7500]no frame?
  • ¥15 乘性高斯噪声在深度学习网络中的应用
  • ¥15 运筹学排序问题中的在线排序
  • ¥15 关于docker部署flink集成hadoop的yarn,请教个问题 flink启动yarn-session.sh连不上hadoop,这个整了好几天一直不行,求帮忙看一下怎么解决
  • ¥15 深度学习根据CNN网络模型,搭建BP模型并训练MNIST数据集
  • ¥15 C++ 头文件/宏冲突问题解决
  • ¥15 用comsol模拟大气湍流通过底部加热(温度不同)的腔体
  • ¥50 安卓adb backup备份子用户应用数据失败
  • ¥20 有人能用聚类分析帮我分析一下文本内容嘛