验证阻塞队列超时机制

原创 2016年08月29日 10:40:43

作者最近学习了一下线程池源码,线程池判断线程是否超时需要回收是根据任务队列超时来判断的,本人初学阻塞队列,不明白是怎么判断超时的,写了个程序验证一下,望指正。

下面附上代码:

/**
 * 验证BlockingQueue中poll方法超时机制
 * 从BlockingQueue中poll元素时,如果队列为空,则等待传入的时间,如果队列任然为空,则表示poll超时
 * @date 2016-8-29
 */
public class Test2 {

private LinkedBlockingQueue<Integer> queue = new LinkedBlockingQueue<Integer>();

private Integer startValue = 0;

private Integer work = null;

//添加任务
class AddThread extends Thread{
public void run() {
//10秒添加一次
while(true){
queue.add(startValue);
startValue++;
try {
Thread.sleep(10000);
} catch (InterruptedException e) {
e.printStackTrace();
}
}
}
}

//取出任务
class PollThread extends Thread{
public void run() {
Long startTime = 0l;
Long endTime = 0l;
while(true){
startTime = System.currentTimeMillis();
try {
//5秒超时
work = queue.poll(5, TimeUnit.SECONDS);
} catch (InterruptedException e) {
e.printStackTrace();
}
endTime = System.currentTimeMillis();
if(work == null){
System.out.println("取出任务超时:" + (endTime - startTime) + "毫秒");
}else{
System.out.println("取出任务用时:" + (endTime - startTime) + "毫秒,任务:" + work);
}
}
}
}

public static void main(String[] args) {
Test2 t2 = new Test2();
AddThread add = t2.new AddThread();
PollThread poll = t2.new PollThread();
add.start();
poll.start();
}
}


运行结果如下:

取出任务用时:1毫秒,任务:0
取出任务超时:5000毫秒
取出任务用时:4999毫秒,任务:1
取出任务超时:5002毫秒
取出任务用时:4999毫秒,任务:2
取出任务超时:5001毫秒

版权声明:本文为博主原创文章,未经博主允许不得转载。

相关文章推荐

从服务端下载图片(主线程阻塞,消息队列机制,从网上下载图片)

看着大神的技术各种高大上,自己怎么能落后呢? 好好加油吧,骚年。对昨天的从服务端下载图片进行复习。主线程阻塞:1,UI停止刷新,应用无法响应用户的操作。 2,耗时操作不应该放在主线程中。 3,A...

主线程阻塞、消息队列机制和图片下载

结合例子,讲解了主线程阻塞、消息队列机制和图片下载,相关知识

安卓的消息队列机制

  • 2012-05-22 09:19
  • 30KB
  • 下载

task-DelayQueue-订单超时实例(task任务,DelayQueue阻塞队列)

很早就对task,queue有兴趣,今天总结一下,做个笔记。 一、对于多任务异步的项目中,task的作用很普遍,最近学习,和小试牛刀了一下,有一些感悟,做个笔记。 二、使用spring task,配...

内核等待队列机制介绍

  • 2008-03-17 09:40
  • 62KB
  • 下载

RabbitMQ消息队列(三):任务分发机制

在上篇文章中,我们解决了从发送端(Producer)向接收端(Consumer)发送“Hello World”的问题。在实际的应用场景中,这是远远不够的。从本篇文章开始,我们将结合更加实际的应用场景来...

基于kafka的大量httpRequest队列控制及mergeRequest机制

kafka 相关

安卓消息机制中的消息队列MessageQueue的插入轮询算法

1.MessageQueue的插入算法 boolean enqueueMessage(Message msg, long when) { if (msg.target == null)...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:深度学习:神经网络中的前向传播和反向传播算法推导
举报原因:
原因补充:

(最多只允许输入30个字)