近期遇到一个问题,后台程序将要承受巨大访问压力,于是将访问暂存于一个linkedlist中,不做任何其他处理,使得响应请求的线程能及时再次响应请求,这里将有另外一个线程从这个linkedlist中取得访问并执行,返回结果。问题就是后一个线程需要不停的判断list的大小,我所做的就是一个无限循环过程,考虑到服务器性能,不知道有没有更好的办法使得能及时知道容器中是否有新请求,而不用在容器中没有请求时做判断。
[b]问题补充:[/b]
感谢llade的回答,我用的jdk是1.6的,这个线程池自己维护的fifo队列有多长,还有它本身维护fifo的效能是不是较高,我可以去试验比较一下效能。
实时监测容器大小如何做到最优效能
- 写回答
- 好问题 0 提建议
- 追加酬金
- 关注问题
- 邀请回答
-
2条回答 默认 最新
- llade163 2008-06-22 12:42关注
后一个线程可以不是一个线程可以是一个线程池,如果你JDK5的话。可以用
Executors.newFixThreadPool(5);得到一个5个线程的线程池。然后把你的请求包装成runnable。线程池自己维护一个FIFO队列,当超过5个任务在同时运行的时候,后续的任务会自动加到队列当中。当运行的5个任务有其中一个已经完成,线程池会从队列中取最先加进去的任务执行。当所有任务都运行完了。5个线程会在那里等待(不消耗CPU时间)。本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 无用评论 打赏 举报
悬赏问题
- ¥50 如何用脚本实现输入法的热键设置
- ¥20 我想使用一些网络协议或者部分协议也行,主要想实现类似于traceroute的一定步长内的路由拓扑功能
- ¥30 深度学习,前后端连接
- ¥15 孟德尔随机化结果不一致
- ¥15 apm2.8飞控罗盘bad health,加速度计校准失败
- ¥15 求解O-S方程的特征值问题给出边界层布拉休斯平行流的中性曲线
- ¥15 谁有desed数据集呀
- ¥20 手写数字识别运行c仿真时,程序报错错误代码sim211-100
- ¥15 关于#hadoop#的问题
- ¥15 (标签-Python|关键词-socket)