验证阻塞队列超时机制

原创 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个站点链接2个后端服务,但1个后端服务有问题,导致访问超时,但请求接口都是分开的。自认为一个服务站点请求超时,不会影响到另外一个请求的,但不是。全部请求都发不出去。为什么呢?...

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

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

linux中的阻塞机制及等待队列

一、阻塞与非阻塞 阻塞调用是没有获得资源则挂起进程,被挂起的进程进入休眠状态,调用的函数只有在得到结果之后才返回,进程继续。 非阻塞是不能进行设备操作时不挂起,或返回,或反复查询,直到可以...

[Linux]阻塞与非阻塞(等待队列、轮询)机制

基本概念 等待队列Wait Queue 定义等待队列头 初始化等待队列头 定义等待队列元素 添加移除等待队列 等待事件 唤醒队列 在等待队列上睡眠 轮询 selectpoll 或 epoll 设备驱动...
  • dearsq
  • dearsq
  • 2016年10月21日 12:03
  • 1171

安卓的消息队列机制

  • 2012年05月22日 09:19
  • 30KB
  • 下载

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

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

内核等待队列机制介绍

  • 2008年03月17日 09:40
  • 62KB
  • 下载

OPNET模拟仿真QoS中队列策略机制

  • 2012年05月15日 19:03
  • 4.93MB
  • 下载
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:验证阻塞队列超时机制
举报原因:
原因补充:

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