OnJava8-Examples/lowlevel/DelayQueueDemo.java

95 lines
2.4 KiB
Java
Raw Normal View History

2016-12-07 10:34:41 -08:00
// lowlevel/DelayQueueDemo.java
// (c)2021 MindView LLC: see Copyright.txt
2015-11-15 15:51:35 -08:00
// We make no guarantees that this code is fit for any purpose.
2016-09-23 13:23:35 -06:00
// Visit http://OnJava8.com for more book information.
2015-06-15 17:47:35 -07:00
import java.util.*;
2017-01-12 16:49:36 -08:00
import java.util.stream.*;
import java.util.concurrent.*;
2015-06-15 17:47:35 -07:00
import static java.util.concurrent.TimeUnit.*;
class DelayedTask implements Runnable, Delayed {
private static int counter = 0;
private final int id = counter++;
private final int delta;
private final long trigger;
protected static List<DelayedTask> sequence =
2017-01-14 15:49:57 -08:00
new ArrayList<>();
2017-05-01 14:33:10 -06:00
DelayedTask(int delayInMilliseconds) {
2015-06-15 17:47:35 -07:00
delta = delayInMilliseconds;
trigger = System.nanoTime() +
NANOSECONDS.convert(delta, MILLISECONDS);
sequence.add(this);
}
@Override public long getDelay(TimeUnit unit) {
2015-06-15 17:47:35 -07:00
return unit.convert(
trigger - System.nanoTime(), NANOSECONDS);
}
@Override public int compareTo(Delayed arg) {
2015-06-15 17:47:35 -07:00
DelayedTask that = (DelayedTask)arg;
if(trigger < that.trigger) return -1;
if(trigger > that.trigger) return 1;
return 0;
}
@Override public void run() {
2017-01-12 16:49:36 -08:00
System.out.print(this + " ");
}
@Override public String toString() {
2017-01-12 16:49:36 -08:00
return
String.format("[%d] Task %d", delta, id);
2015-06-15 17:47:35 -07:00
}
public String summary() {
2017-01-12 16:49:36 -08:00
return String.format("(%d:%d)", id, delta);
2015-06-15 17:47:35 -07:00
}
2017-01-12 16:49:36 -08:00
public static class EndTask extends DelayedTask {
2017-05-01 14:33:10 -06:00
EndTask(int delay) { super(delay); }
@Override public void run() {
2017-01-12 16:49:36 -08:00
sequence.forEach(dt ->
2017-01-14 15:49:57 -08:00
System.out.println(dt.summary()));
2015-06-15 17:47:35 -07:00
}
}
}
public class DelayQueueDemo {
2017-01-12 16:49:36 -08:00
public static void
main(String[] args) throws Exception {
DelayQueue<DelayedTask> tasks =
2017-01-14 15:49:57 -08:00
Stream.concat( // Random delays:
2017-01-12 16:49:36 -08:00
new Random(47).ints(20, 0, 4000)
.mapToObj(DelayedTask::new),
// Add the summarizing task:
2017-01-13 07:03:28 -08:00
Stream.of(new DelayedTask.EndTask(4000)))
2017-01-12 16:49:36 -08:00
.collect(Collectors
.toCollection(DelayQueue::new));
2017-01-13 07:03:28 -08:00
while(tasks.size() > 0)
tasks.take().run();
2015-06-15 17:47:35 -07:00
}
2015-09-07 11:44:36 -06:00
}
/* Output:
[128] Task 12 [429] Task 6 [555] Task 2 [551] Task 13
[693] Task 3 [809] Task 15 [961] Task 5 [1258] Task 1
[1258] Task 20 [1520] Task 19 [1861] Task 4 [1998] Task
17 [2200] Task 8 [2207] Task 10 [2288] Task 11 [2522]
Task 9 [2589] Task 14 [2861] Task 18 [2868] Task 7
[3278] Task 16 (0:4000)
2017-01-12 16:49:36 -08:00
(1:1258)
(2:555)
(3:693)
(4:1861)
(5:961)
(6:429)
(7:2868)
(8:2200)
(9:2522)
(10:2207)
(11:2288)
(12:128)
(13:551)
(14:2589)
(15:809)
(16:3278)
(17:1998)
(18:2861)
(19:1520)
(20:1258)
2015-09-07 11:44:36 -06:00
*/