码迷,mamicode.com
首页 > 编程语言 > 详细

011-多线程-JUC集合-Queue-PriorityBlockingQueue和DelayQueue

时间:2019-07-04 14:10:48      阅读:201      评论:0      收藏:0      [点我收藏+]

标签:缓存系统   pareto   任务   指定元素   支持   阻塞队列   需要   必须   注意   

一、PriorityBlockingQueue简介

  PriorityBlockingQueue是一个支持优先级的无界阻塞队列。默认情况下元素采用自然顺序升序排列。也可以自定义类实现compareTo()方法来指定元素排序规则,或者初始化PriorityBlockingQueue时,指定构造参数Comparator来对元素进行排序。但需要注意的是不能保证同优先级元素的顺序。

二、DelayQueue

  DelayQueue是一个支持延时获取元素的无界阻塞队列。队列使用PriorityQueue来实现。队列中的元素必须实现Delayed接口,在创建元素时可以指定多久才能从队列中获取当前元素。只有在延迟期满时才能从队列中提取元素。

  DelayQueue非常有用,可以运用在以下两个应用场景: 

    缓存系统的设计:使用DelayQueue保存缓存元素的有效期,使用一个线程循环查询DelayQueue,一旦能从DelayQueue中获取元素时,就表示有缓存到期了。 
    定时任务调度:使用DelayQueue保存当天要执行的任务和执行时间,一旦从DelayQueue中获取到任务就开始执行,比如Timer就是使用DelayQueue实现的。

011-多线程-JUC集合-Queue-PriorityBlockingQueue和DelayQueue

标签:缓存系统   pareto   任务   指定元素   支持   阻塞队列   需要   必须   注意   

原文地址:https://www.cnblogs.com/bjlhx/p/11131573.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!