INTERFACES IN DEPTH 90 | BOOKS ON JAVA 9 07 JANUARY/FEBRUARY 2018 REACTIVE magazine PROGRAMMING By and for the Java community Handling large data streams eiciently 16 32 61 69 REACTIVE RXJAVA— REACTORS IN CQRS: NOT PROGRAMMING REACTIVE SPRING 5.0 THE USUAL WITH JAX-RS LIBRARY FOR CRUD THE JVM ORACLE.COM/JAVAMAGAZINE ////ttaabbllee ooff ccoonntteennttss // COVER FEATURES 32 61 69 GOING REACTIVE REACTIVE SPRING COMMAND QUERY WITH ECLIPSE VERT.X RESPONSIBILITY By Josh Long AND RXJAVA SEGREGATION Proceeding from fundamentals, WITH JAVA By Clement Escoier use the Spring Framework and Julien Ponge to quickly build a reactive By Sebastian Daschner Building fast scalable systems application. Get around the limitations of with one of the most popular CRUD by using event streams 16 reactive Java libraries and an eventually consistent architecture. REACTIVE PROGRAMMING WITH JAX-RS By Mert Çalışkan Using an asynchronous approach and staging to develop responsive reactive apps OTHER FEATURES DEPARTMENTS 90 101 05 13 The Evolving Nature Fix This From the Editor User Groups of Java Interfaces The decline of dynamic typing The Denver JUG By Simon Roberts and Mikalai Zaikin By Michael Kölling Our latest quiz with questions that 07 114 Understanding multiple inheritance test intermediate and advanced Java Books Contact Us in Java knowledge of the language Reviews of Java 9 Modularity and Have a comment? Suggestion? Want to Java 9 for Programmers submit an article proposal? Here’s how. 10 Events Upcoming Java conferences and events 02 COVER ART BY PEDRO MURTEIRA ORACLE.COM/JAVAMAGAZINE ////////////////////////////////// JANUARY/FEBRUARY 2018 EDITORIAL PUBLISHING Editor in Chief Publisher and Audience Development Andrew Binstock Director Managing Editor Karin Kinnear Claire Breen Audience Development Manager Copy Editors Jennifer Kurtz Karen Perkins, Leslie Steere Technical Reviewer ADVERTISING SALES Stephen Chin Sales Director Tom Cometa DESIGN Account Manager Senior Creative Director Mark Makinney Francisco G Delgadillo Mailing-List Rentals Design Director Contact your sales representative. Richard Merchán Senior Designer RESOURCES Arianna Pucherelli Oracle Products Designer +1.800.367.8674 (US/Canada) Jaime Ferrand Oracle Services Senior Publication Designer +1.888.283.0591 (US) Sheila Brennan Production Designer Kathy Cygnarowicz ARTICLE SUBMISSION If you are interested in submitting an article, please email the editors. You’ve Earned It SUBSCRIPTION INFORMATION Subscriptions are complimentary for qualified individuals who complete the subscription form. MAGAZINE CUSTOMER SERVICE Display Your Oracle Certification Digital Badge [email protected] PRIVACY Oracle Publishing allows sharing of its mailing list with selected third parties. If you prefer that your mailing address or email address not be included in this program, contact Customer Service. Copyright © 2018, Oracle and/or its affiliates. All Rights Reserved. No part of this publication may be reprinted or otherwise reproduced without permission from the editors. JAVA MAGAZINE IS PROVIDED ON AN “AS IS” BASIS. ORACLE EXPRESSLY DISCLAIMS ALL WARRANTIES, WHETHER EXPRESS OR IMPLIED. IN NO EVENT SHALL ORACLE BE LIABLE FOR ANY DAMAGES OF ANY KIND ARISING FROM YOUR USE OF OR RELIANCE ON ANY INFORMATION PROVIDED HEREIN. Opinions ASSOCIATE PROFESSIONAL MASTER EXPERT SPECIALIST expressed by authors, editors, and interviewees—even if they are Oracle employees—do not necessarily reflect the views of Oracle. The information is intended to outline our general product direction. It is intended for information purposes only, and may not be incorporated into any contract. It is not a commitment to deliver any material, code, or functionality, and should not be relied upon in making purchasing decisions. The development, release, and timing of any features or functionality described for Oracle’s Claim your certification badge and validate products remains at the sole discretion of Oracle. Oracle and Java are registered trademarks of Oracle Corporation and/or its affiliates. Other names may be trademarks of their respective owners. your skills across all online platforms. Java Magazine is published bimonthly and made available at no cost to qualified subscribers by Oracle, 500 Oracle Parkway, MS OPL-3A, Redwood City, CA 94065-1600. 03 ORACLE.COM/JAVAMAGAZINE ///////////////////////////////// JANUARY/FEBRUARY 2018 Register Now Oracle Code is BACK! | 1-Day, Free Event Explore the Latest Developer Trends: • DevOps, Containers, Microservices, and APIs • MySQL, NoSQL, Oracle, and Open Source Databases • Development Tools and Low Code Platforms • Open Source Technologies • Machine Learning, AI, and Chatbots Coming to a city near you: developer.oracle.com/code //from the editor / Java in the Cloud The Decline of Dynamic Typing Oracle Cloud delivers A feature once viewed as a convenience has become more troublesome than it’s worth. high-performance and battle-tested platform and infrastructure services I for the most demanding f you follow the rise and fall of programming As a quick refresher, static typing refers to a Java apps. languages—either from the comfort of an type system that makes it possible to know the armchair, ensconced with your preferred tools type of every data item and expression at compile Oracle Cloud. but interested in other people’s choices, or from time. Speciically, this means that the language Built for modern app dev. a keyboard, happy to hyperkinetically try out all does not allow the use of types that are resolved Built for you. kinds of new idioms—you will have noticed an at runtime. For example, in JavaScript (a dynami- unmistakable trend in modern language design: cally typed language) a variable is declared by a preference for static typing. using var, rather than a speciic type. A variable Look at the major languages that have can hold a string, a number, or a boolean at vari- emerged in the past decade—Go, Swift, Kotlin, ous times in the same program. In contrast, static and Rust—they’re all statically typed. Moreover, types, such as those found in Java, force you to languages that were once dynamic have added declare the type when you deine the variable. static typing. The most conspicuous example is Static typing provides several important the recent set of updates to JavaScript (or more advantages. The irst advantage is that the com- Start here: accurately, ECMAScript). Apple’s choice to replace piler can perform signiicant program verii- developer.oracle.com dynamically typed Objective-C with Swift also cation. Because the compiler knows that i, for follows this trend. example, has been declared an integer, it can #developersrule PHOTOGRAPH BY BOB ADLER/THE VERBATIM AGENCY 05 ORACLE.COM/JAVAMAGAZINE ////////////////////////////////// JANUARY/FEBRUARY 2018 //from the editor / check that all places where i is this aspect is invaluable. Stepping quick and easy development, was used do expect or at least can through code in which the con- a welcome step forward. support an integer. Likewise, tents of a variable can change But while dynamic languages static source code checkers are type is not anybody’s idea of fun. have retained considerable popu- much more capable when they The dynamic aspect also intro- larity, some 15 years later the have complete type information. duces a kind of uncertainty when cost of dynamic typing is more A second key beneit is per- a bug is discovered. Say the vari- apparent as codebases grow The Best formance. A runtime that must able i, which previously held an larger, performance becomes determine the type of every vari- integer, now holds a string; was more important, and the cost Resource able and the methods that are that a spelling error by the devel- of maintenance rises steadily. available to it while the program oper, who meant to store it in u, While those dynamically typed for Modern is running has signiicant over- or was it an intentional reuse languages will surely be with head that statically typed lan- of a variable? And if the latter, us for a long time, it is unlikely Cloud Dev guages don’t require. In part, this how should you understand that many new languages will is why many of the traditional other instances of i in the code- embrace the model. dynamic languages—Python, base? These problems are bear- The Oracle Developer Perl, and Ruby—run much more able in the small but extremely Andrew Binstock, Editor in Chief Gateway is the best place slowly than statically typed troublesome in the large. This [email protected] to jump-start your modern options. An exception to this problem—precisely as it appears @platypusguy cloud development skills might be JavaScript, which runs in large projects—was the pri- with free trials, downloads, much faster than many dynamic mary motivation for Microsoft to tutorials, documentation, languages. But this speed is a create TypeScript, its superset of and more. comparatively recent advance JavaScript that added one princi- driven by massive investments by pal feature: types. Trials. Downloads. Google and Microsoft into their Dynamic typing lourished Tutorials. Start here: respective JavaScript engines. in popular languages in the mid- developer.oracle.com A inal beneit, which in my 1990s (Python, Ruby, JavaScript, view is the one that has turned and PHP all appeared within the tide against dynamic lan- a four-year window), when PC guages, is maintainability. First, hardware had become power- for readability, it is much easier ful enough to run languages developer.oracle.com to understand code if types are that needed runtime support. At declared statically because it is the time, tools were primitive #developersrule then possible to tell exactly what and compile times were long, so you’re looking at. For debugging, dynamic typing, which facilitated 06 ORACLE.COM/JAVAMAGAZINE ////////////////////////////////// JANUARY/FEBRUARY 2018 // / java books Java 9 Books The wave of books for the new release is now arriving. A s with all previous major releases, the arrival of Java 9 has unleashed a wave of books examining and explaining its new features. The next few book columns will review important titles that you’ll want to be aware of. In this installment, I look at two books, one speciically on Java 9 modules and one on the larger language. JAVA 9 MODULARITY modular JAR iles while continu- plenty of examples. It’s a very By Sander Mak and Paul Bakker ing to provide the traditional bits readable guide. The remaining that run on JVMs prior to this 180 pages are where the value is new release. Although you cer- really apparent. These pages start tainly can run apps on the Java 9 out covering modularity patterns, runtime without using modules, which are ways of architecting it is expected that most sites will modules so that they work together switch over to module-based bina- ideally. The goal is to ind the bal- ries during the next few years. ance between devising modules Some sites, especially those wres- that naturally (that is, conceptu- tling with so-called “classpath ally) it together while creating the hell,” will likely ind incentive to minimum number of dependencies move to modules as quickly as pos- on external modules. This tension sible. Those sites will discover a is familiar to Java architects The introduction of modules in trove of useful information in Mak designing JARs. However, the Java 9 signiicantly changed how and Bakker’s new work. impetus to get the design right in Java applications are built and The book opens with a detailed traditional JARs historically has delivered. These changes are par- explanation of what modules are been more of a desirable goal than ticularly important for developers and how they work. The irst four an imperative. With modules, it of Java libraries, who need to work chapters cover the anatomy and becomes a much more serious out their strategy for delivering use of modules in detail, with proposition. The whole point of 07 ORACLE.COM/JAVAMAGAZINE ///////////////////////////////// JANUARY/FEBRUARY 2018 //java books / modularity is to manage depen- reader to know much more than Core Java, which I’ve reviewed magazine. It was one of our most dencies intelligently to get rid of how to program in Java; low-level previously in this column. Both popular articles in 2017. classpath conlicts and enable details (such as how classloaders entrants are ine works, and This is the irst book I’ve delivery of modestly sized binaries. work) are explained on the ly. This choosing one or the other depends seen on Java 9 that has in-depth The authors tackle many book was explicitly recommended in large part on your personal pref- coverage of JShell, the new REPL aspects of the problem: splitting at Devoxx in November by mem- erences. (Note: Core Java has not introduced in Java 9. Its peda- modules, aggregating modules, and bers of the core Java team, and I been released for Java 9, although gogical beneits are not lost on creating new modules as facades. fully agree with their assessment. an abridged version is available.) the authors, who drill into how They then move into technical —Andrew Binstock The Deitels’ book is notable for to make best use of it both as problems such as encapsulating its hands-on orientation: it is code- a programming aid and as a JAVA 9 FOR resources, after which they explore intensive with numerous examples. teaching tool. PROGRAMMERS building modules speciically for It even includes a full project (com- In addition to the language (4TH EDITION) use in containers. prising 77 pages) that goes from proper, the book covers JavaFX, By Paul Deitel and Harvey Deitel The inal sections have pointers initial design of an ATM machine JDBC, and JPA. Each chapter for library designers and a handy all the way through to comple- includes self-review exercises, section on coniguring tools, such tion. The design portion includes with accompanying solutions; the as Maven and Gradle, for modules. introduction to the basic Uniied explanations are sprinkled with Wedged into all this goodness Modeling Language (UML) dia- caveats for dangers, reminders is a lengthy discussion of how to grams, putting together the object- about good programming prac- run Java 9 without migrating to oriented design, and incrementally tices, and tips on writing idiomatic modules. This will be particularly developing the code. Working Java. In other words, this is a com- useful to sites that are planning through this project is an excellent plete presentation. to adopt modules at some future education quite apart from the use I have only one gripe with this point and want to understand the of Java. volume, and that is the excessive full scenario, starting with limited Java 9’s most important fea- use of color highlighting in the migration to the new runtime and This book is the irst of the com- tures receive rich coverage. For code. Even if you’re a fan of then slowly implementing the con- prehensive language tutorials example, the section on modules brightly colored code, your eyes siderations presented in the rest of to come to market that includes is a full 52 pages that explore the will quickly tire of reading pale the book. extensive coverage of Java 9. In this need for modules, how modules blue text or squinting at bright Taken together, all these topics context, it competes with other work, and how to use them in your green comments on a canary- represent a comprehensive over- 1,000-page volumes that present own code. To get a sense of the yellow background. But if you can view of Java 9 modularity. The writ- the entire language and its princi- hands-on nature of the explana- handle that, you’ll have a very ine ing is clear and easy to understand, pal APIs. For example, it competes tions, see the lightly edited excerpt book that does an excellent job of and the authors do not expect the with Cay Horstmann’s excellent from this section that ran in this presenting Java 9. —AB 08 ORACLE.COM/JAVAMAGAZINE ///////////////////////////////// JANUARY/FEBRUARY 2018 Your Destination for Oracle and Java Expertise Written by leading experts in Java, Oracle Press books offer the most definitive, complete, and up-to-date coverage of Java available. Java: A Beginner’s Guide, Java: The Complete OCA Java SE 8 Rapid Modernization 7th Edition Reference, Programmer I Exam Guide of Java 10th Edition (Exam 1Z0-808) Applications Herb Schildt Herb Schildt Kathy Sierra, Bert Bates G. Venkat Revised to cover Java SE 9, this book gets you started Updated for Java SE 9, this book Get complete coverage of all Adopt a high-performance programming in Java right away. shows how to develop, compile, objectives for Exam 1Z0-808. enterprise Java application debug, and run Java programs. Electronic practice exam modernization strategy. questions are included. Available in print and eBook formats. www.OraclePressBooks.com • @OraclePress