OnJava8-Examples/concurrent/CompletableApplyAsync.java

32 lines
842 B
Java
Raw Normal View History

2016-12-21 11:06:49 -08:00
// concurrent/CompletableApplyAsync.java
2020-10-07 13:35:40 -06:00
// (c)2020 MindView LLC: see Copyright.txt
2016-12-21 11:06:49 -08:00
// We make no guarantees that this code is fit for any purpose.
// Visit http://OnJava8.com for more book information.
import java.util.concurrent.*;
import onjava.*;
public class CompletableApplyAsync {
public static void main(String[] args) {
Timer timer = new Timer();
CompletableFuture<Machina> cf =
CompletableFuture.completedFuture(
new Machina(0))
.thenApplyAsync(Machina::work)
.thenApplyAsync(Machina::work)
.thenApplyAsync(Machina::work)
.thenApplyAsync(Machina::work);
System.out.println(timer.duration());
System.out.println(cf.join());
System.out.println(timer.duration());
}
}
/* Output:
116
2016-12-21 11:06:49 -08:00
Machina0: ONE
Machina0: TWO
Machina0: THREE
Machina0: complete
Machina0: complete
552
2016-12-21 11:06:49 -08:00
*/