验证阻塞队列超时机制

原创 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毫秒

10w定时任务,如何高效触发超时

一、缘起 很多时候,业务有定时任务或者定时超时的需求,当任务量很大时,可能需要维护大量的timer,或者进行低效的扫描。   例如:58到家APP实时消息通道系统,对每个用户会维护一...
  • u011676417
  • u011676417
  • 2017年03月19日 12:15
  • 512

一个网站优秀的登录验证设计方案(登录页面的超时以及密码加上时间戳)

1 有隐患登录的验证方式  1.1 有隐患登录的验证方式介绍       如图所示,从firebug上抓取到我们输入完用户名和密码之后的信息,url:http://xxx.com/doLogin.ph...
  • CleverCode
  • CleverCode
  • 2015年05月04日 15:12
  • 4447

Dubbo基本原理机制-超时、注册

from: http://blog.csdn.net/paul_wei2008/article/details/19355681Dubbo缺省协议采用单一长连接和NIO异步通讯,适合于小数据量大并发的...
  • gadbee5
  • gadbee5
  • 2015年01月15日 14:29
  • 1639

netty 超时机制和心跳机制

http://blog.163.com/linfenliang@126/blog/static/127857195201467112958326/
  • limuzi13
  • limuzi13
  • 2016年06月12日 17:44
  • 980

Session、Session的跟踪机制、Session的超时管理、IE禁用Cookie后的session处理

Session、Session的跟踪机制、Session的超时管理、IE禁用Cookie后的session处理 使用Cookie和附加URL参数都可以将上一次请求的状态信息传递到下一次请求中,但...
  • fengdongkun
  • fengdongkun
  • 2012年10月31日 20:56
  • 4187

TCP-IP详解:超时重传机制

超时重传是TCP保证数据传输可靠性的又一大措施
  • wdscq1234
  • wdscq1234
  • 2016年09月11日 00:52
  • 4123

Java任务超时处理机制实现

1问题描述     在应用软件的开发中,经常会遇到这样的一种需求:需要实现一个方法来执行某种任务,而这个方法的执行时间不能超过指定值,如果超时,则调用者不管这个方法将来是否可能执行成功,都要中断...
  • fangquan1980
  • fangquan1980
  • 2016年09月07日 16:10
  • 5472

HttpClient超时机制算法探讨

前面提到了一个需要管理所有request请求的timeout,原先文章的一种处理方式是起一个异步线程的方式,通过jdk的unsafe的await机制控制timeout。    存在的问题: 1.  创...
  • kobejayandy
  • kobejayandy
  • 2014年01月04日 23:59
  • 1756

LinkedBlockingQueue阻塞队列offer()操作抛出中断异常

说明 在使用LinkedBlockingQueue的offer方法时,出现了中断异常,现分析一下出现这个中断异常的原因。 会产生中断异常的Demo import java.util.concur...
  • qq1332479771
  • qq1332479771
  • 2017年06月28日 00:12
  • 538

请求、响应与超时机制详解

请求、响应与超时机制详解在C/S软件模型中,往往都遵循这请求和响应的机制,而且往往还伴随着超时控制。即:A发送请求,然后等待B的响应,同时开始超时计时,如果在超时时间内成功接收到响应,则结束等待和计时...
  • qiuzhiqian1990
  • qiuzhiqian1990
  • 2017年03月16日 17:04
  • 863
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:验证阻塞队列超时机制
举报原因:
原因补充:

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