011-多线程-JUC集合-Queue-PriorityBlockingQueue和DelayQueue
2020-12-13 05:07
标签:缓存系统 pareto 任务 指定元素 支持 阻塞队列 需要 必须 注意 一、PriorityBlockingQueue简介 PriorityBlockingQueue是一个支持优先级的无界阻塞队列。默认情况下元素采用自然顺序升序排列。也可以自定义类实现compareTo()方法来指定元素排序规则,或者初始化PriorityBlockingQueue时,指定构造参数Comparator来对元素进行排序。但需要注意的是不能保证同优先级元素的顺序。 二、DelayQueue DelayQueue是一个支持延时获取元素的无界阻塞队列。队列使用PriorityQueue来实现。队列中的元素必须实现Delayed接口,在创建元素时可以指定多久才能从队列中获取当前元素。只有在延迟期满时才能从队列中提取元素。 DelayQueue非常有用,可以运用在以下两个应用场景: 缓存系统的设计:使用DelayQueue保存缓存元素的有效期,使用一个线程循环查询DelayQueue,一旦能从DelayQueue中获取元素时,就表示有缓存到期了。 011-多线程-JUC集合-Queue-PriorityBlockingQueue和DelayQueue 标签:缓存系统 pareto 任务 指定元素 支持 阻塞队列 需要 必须 注意 原文地址:https://www.cnblogs.com/bjlhx/p/11131573.html
定时任务调度:使用DelayQueue保存当天要执行的任务和执行时间,一旦从DelayQueue中获取到任务就开始执行,比如Timer就是使用DelayQueue实现的。
文章标题:011-多线程-JUC集合-Queue-PriorityBlockingQueue和DelayQueue
文章链接:http://soscw.com/essay/30454.html