Book Image

Java 9: Building Robust Modular Applications

By : Dr. Edward Lavieri, Peter Verhas, Jason Lee
Book Image

Java 9: Building Robust Modular Applications

By: Dr. Edward Lavieri, Peter Verhas, Jason Lee

Overview of this book

Java 9 and its new features add to the richness of the language; Java is one of the languages most used by developers to build robust software applications. Java 9 comes with a special emphasis on modularity with its integration with Jigsaw. This course is your one-stop guide to mastering the language. You'll be provided with an overview and explanation of the new features introduced in Java 9 and the importance of the new APIs and enhancements. Some new features of Java 9 are ground-breaking; if you are an experienced programmer, you will be able to make your enterprise applications leaner by learning these new features. You'll be provided with practical guidance in applying your newly acquired knowledge of Java 9 and further information on future developments of the Java platform. This course will improve your productivity, making your applications faster. Next, you'll go on to implement everything you've learned by building 10 cool projects. You will learn to build an email filter that separates spam messages from all your inboxes, a social media aggregator app that will help you efficiently track various feeds, and a microservice for a client/server note application, to name just a few. By the end of this course, you will be well acquainted with Java 9 features and able to build your own applications and projects. This Learning Path contains the best content from the following two recently published Packt products: • Mastering Java 9 • Java 9 Programming Blueprints
Table of Contents (33 chapters)
Title Page - Courses
Packt Upsell - Courses
Preface
25
Taking Notes with Monumentum
Bibliography
Index

Reactive Programming


Reactive programming is when applications react to an asynchronous data stream as it occurs. The following image illustrates the flow:

Reactive programming is not a fancy software engineering term only used by academics. It is, in fact, a programming model that can result in much greater efficiencies as opposed to the more common method of having applications iterate over data that is in memory.

There is more to reactive programming. First, let's consider that the data stream is provided by a publisher in an asynchronous manner to the subscriber.

Note

Data streams are a binary input/output of strings and primitive data types. The DataInput interface is used for an input stream and the DataOutput interface is used for output streams.

Processors, or a chain of processors, can be used to transform the data stream without the publisher or subscriber being impacted. In the following example, the Processors work on the stream of data without Publisher or Subscriber involvement...