Reactive or Asynchronous Programming in Java

Story

Reactive programming is pretty hottest talk for a while in programming worlds, both front end and back end. Java has the ability since 8th release. However, I haven’t fully or regularly applied in general coding life, which is shame. I know as a geek you have to adopt the latest and popular techniques quicker and faster. No excuse, let’s get hands dirty with it now.

Learning

Why CompletableFuture?

Limitations of Future (Since Java 1.5, see more)

  1. It cannot be manually completed:

    Let’s say that you’ve written a function to fetch the latest price of an e-commerce product from a remote API. Since this API call is time-consuming, you’re running it in a separate thread and returning a Future from your function. Now, let’s say that If the remote API service is down, then you want to complete the Future manually by the last cached price of the product. Can you do this with Future? No!

  2. You cannot perform further action on a Future’s result without blocking:

    Future does not notify you of its completion. It provides a get() method which blocks until the result is available. You don’t have the ability to attach a callback function to the Future and have it get called automatically when the Future’s result is available.

  3. Multiple Futures cannot be chained together :

    Sometimes you need to execute a long-running computation and when the computation is done, you need to send its result to another long-running computation, and so on. You can not create such asynchronous workflow with Futures.

  4. You can not combine multiple Futures together :

    Let’s say that you have 10 different Futures that you want to run in parallel and then run some function after all of them completes. You can’t do this as well with Future.

  5. No Exception Handling :

    Future API does not have any exception handling construct.

References

(Updated: )

comments powered by Disqus