[心缘地方]同学录
首页 | 功能说明 | 站长通知 | 最近更新 | 编码查看转换 | 代码下载 | 常见问题及讨论 | 《深入解析ASP核心技术》 | 王小鸭自动发工资条VBA版
登录系统:用户名: 密码: 如果要讨论问题,请先注册。

[备忘]关于java的延迟队列DelayQueue

上一篇:[备忘]jedis池设置超时时间
下一篇:[备忘]为什么矩形也叫做长方形?

添加日期:2024/12/14 6:11:08 快速返回   返回列表 阅读20次
参考:https://developer.aliyun.com/article/913677

延迟队列DelayQueue,里面的元素需要实现Delayed接口,需要写
long getDelay(TimeUnit unit);
方法。

里面实际是PriorityQueue,优先级队列,
使用的堆排序,就是一个二叉树,

小堆,就是小值在上面,
大堆,就是大值在上面。
堆中每个节点的值都必须小于等于(或者大于等于)其子节点的值
左右兄弟节点,不一定谁大。

add节点时,放到队列尾部,就是树的最底下,最右边,然后顺着树,
从下往上比较,确定位置。

poll节点时,直接拿走头节点,然后把尾节点放到头节点,然后从上往下比较,
跟两个子节点较小的那个,互换位置,如此反复,直到下沉确定位置。

由于add或poll时,不是整个树的完全排序,
所以存在可能性,某个节点位置特殊,一直没有变化位置,
也就一直无法出列(只有移动到头部才能出列)

getDelay()方法只有比较位置时才会调用。注意!!


 

评论 COMMENTS
没有评论 No Comments.

添加评论 Add new comment.
昵称 Name:
评论内容 Comment:
验证码(不区分大小写)
Validation Code:
(not case sensitive)
看不清?点这里换一张!(Change it here!)
 
评论由管理员查看后才能显示。the comment will be showed after it is checked by admin.
CopyRight © 心缘地方 2005-2999. All Rights Reserved