Book Image

Java 11 and 12 ??? New Features

By : Mala Gupta
Book Image

Java 11 and 12 ??? New Features

By: Mala Gupta

Overview of this book

With its new six-monthly release cadence, Java is moving forward faster. In addition to planned version releases, a lot of work is currently being undertaken on various Java projects at Oracle. In order to make best use of the new features in their applications and libraries, you must be well-versed with the most recent advancements. Java 11 and 12 – New Features will take you through the latest developments in Java, right from variable type inference and simplified multithreading through to performance improvements, which are covered in depth to help you make your applications more efficient. This book explains the relevance and applicability of Java's new features, and answers your questions on whether to invest in migrating to new Java versions and when to migrate. You'll also get to grips with platform features, such as AppCDS and new garbage collectors, to tune and optimize your application—from reduced launch time and latency to improved performance and throughput. By the end of this book, you will be equipped with a thorough understanding of the new features of Java 11, 12, and Project Amber, and possess the skills to apply them with a view to improving your application's performance.
Table of Contents (23 chapters)
Free Chapter
1
Section 1: JDK 10
6
Section 2: JDK 11
13
Section 3: JDK 12
16
Section 4: Project Amber

Shenandoah – a low-pause-time GC

Proposed and developed by engineers at Red Hat, Shenandoah GC promises significantly low pauses. It is a region-based GC that collects garbage in a parallel and concurrent manner. It is interesting to note that the pause times are independent of the application's live data.

With hardware engineering and lower costs, servers have more memory and processing power than ever before. Modern applications are increasingly demanding lower pause timeswith Service Level Agreement (SLA) applications that guarantee response times of 10 to 500 ms. To meet the lower end of this range, a GC should be able to accomplish multiple tasks, including the following:

  • Use algorithms that enable programs to execute with the given memory
  • Keep the pause times low (that is, below 10 ms)

Is this attainable with, say, a Java application that uses 200 GB...