/awesome-java8

Curated list of useful, if not amazing, resources that take advantage of Java 8 and "Modern Java" thinking.

Creative Commons Zero v1.0 UniversalCC0-1.0

Awesome Java 8 Build Status Awesome

A truly curated list of useful, if not amazingly awesome, tools, libraries, frameworks, and other resources that take advantage of (or even require) Java 8 features, such as Lambdas, or have a more modern approach to writing Java code. Those that require Java 8 are marked with an 🎱 emoji (for "eight ball" or sometimes "billiards").

If you want a larger list of Java resources not specific to Java 8, check out Awesome Java.


Contents


Libraries and Frameworks

Libraries and frameworks become part of your runtime artifact. Libraries consist of code that you call, whereas frameworks require that you inherit from classes or implement interfaces defined in that framework. Modern Java prefers the delegation model of Libraries vs. the inheritance model of frameworks, however in some cases, frameworks might be worth the inheritance cost, e.g., web frameworks.

Caching Libraries

  • Caffeine - High performance Java 8-based in-memory caching library providing a near optimal "hit rate". Well-documented and flexible. 🎱

Distributed Systems libraries

Libraries that support distributed systems, e.g., queues, key-value stores, and quorum/consensus.

  • Atomix - Event-driven framework for coordinating fault-tolerant distributed systems built on the Raft consensus algorithm. 🎱

Functional libraries

Libraries that make Java 8 more functional, especially filling in the gaps in streams. For strictly stream enhancements, go to the Streams libraries section.

  • Derive4J - Code generator for user-defined algebraic data types (aka sum types) based on an enhanced "visitor" pattern. Provides structural pattern matching, laziness, functional setters (return a copy of an object with one field modified) & more. 🎱
  • Vavr - Adds the notion of Tuples, along with immutable Values and Pattern Matching, to make it easier to write more functional Java code. (Formerly known as Javaslang.) 🎱
  • jOOλ - Part of the jOOQ series of libraries, provides more Functions, Tuples, and Seq that provides methods like crossJoin(), join(), and groupBy(). 🎱
  • NoException - Allows checked exceptions in functional interfaces and converts exceptions to Optional return. 🎱
  • ProtonPack - Offers about a dozen utilities for Stream, e.g., takeWhile, zip, aggregate, and a unique collector. 🎱

General-purpose libraries

For libraries with many features that don't fit in a single category. Honestly, this section was just created so that it can hold Guava, which as of Release 21 requires Java 8+.

  • Guava - One of the most widely used and well-written general-purpose Java libraries. As of Release 21, only works with Java 8 (or later). 🎱

Interoperability libraries

Not sure what to call these other than interoperability libraries, i.e., libraries that make it easier to work with existing libraries that Java 8 provides. I could be convinced to put this under Functional libraries...

  • Cyclops - Very modular, so only include what you need. From function exception handling (try), to generic monad operations, to pattern matching. Specific integrations to Javaslang, functionaljava, and Guava. 🎱

Microservices

While the term can sometimes be ambiguous, hopefully it'll become more clear as new libraries and frameworks become available. This section may include entire frameworks, or libraries that help with coordinating and connecting separately deployed services (aka microservices). For HTTP-based services, see Web App/API frameworks.

  • Apollo - A library for writing HTTP microservices that focuses on composability and simplicity, with high performance using modern Java idioms and features. 🎱
  • SnoopEE - While this is "experimental", it's worth looking at if you're coming to microservices from a "slimmed down" Java EE point of view and need something to handle service discovery. This was shown in a JavaOne 2015 conference talk here. 🎱

Networking libraries

Perhaps this belongs in "distributed systems libraries", since dist-sys requires resiliency, though I like calling out resiliency as it's often overlooked. I'll leave this here for now until someone has an opinion.

  • Resilience4j - A lightweight, easy-to-use, fault-tolerance library designed for Java8 and functional programming (inspired by Netflix's Hystrix). In addition to circuit-breakers, also retries, rate-limiting, and metrics. 🎱

Persistence libraries

  • Speedment - A fluent database access library that looks just like Java 8 code, using the Stream API for querying. Supports MySQL, MariaDB, and PostgreSQL. 🎱

Reactive libraries

Focused on "pulling" items from a stream. There may be overlap between these libraries and the Functional ones (above), but the ones here are primarily/exclusively focused on the Reactive way of thinking about streams.

  • Cyclops React - A library that focuses on users needing async and lazy streams (formerly Simple React). Very well documented with lots of diagrams (yay!). 🎱
  • Project Reactor - A second-generation Reactive library for building non-blocking applications on the JVM based on the Reactive Streams Specification. It directly interacts with the Java 8 functional API, Completable Future, Stream and Duration. 🎱

Streams libraries

These are libraries that enhance the existing Java 8 Streams, but aren't trying to define a completely new API. I could be convinced to put these under the Functional libraries, but until then...

  • StreamEx - Does what it says: enhances the Java 8 streams. The "cheat sheet" is really nice: if you know what you want (e.g., swap keys and values coming from entries in a map), it tells you how to get it. 🎱

Testing

  • AssertJ - Fluent assertions for Java unit testing, with the 3.0 release requiring Java 8. 🎱
  • Lambda Behave - BDD-oriented framework that leverages lambdas to make tests more "behavioral". If you've seen Jasmine or Spock, this will be familiar. 🎱
  • Mockito - The Java 8-specific version of the wonderful mocking library, Mockito. Works great with AssertJ. 🎱

Web App/API frameworks

Frameworks (and micro-frameworks) that make it easy to create services that provide Web APIs (aka REST), and/or full web sites without a "full-blown" JAX-RS implementation.

  • Bootique - A "minimally opinionated" web framework that leverages Google's Guice dependency-injection library to include modules such as JOOQ, Curator, Jersey, Kafka, Metrics, and more. 🎱
  • Jooby Project - A modular web framework that supports multiple servers (Netty, Jetty, and Undertow), Websockets, etc., and can be used in many different ways by including a wide variety of modules, e.g., provide a full MVC web site, or just provide APIs. 🎱
  • Play Framework - The popular Play Framework, from Typesafe, is "reactive" and built on Akka (the Actor framework) and supports non-blocking I/O, and is stateless. 🎱
  • Ratpack - Reactive framework built on the Netty engine for non-blocking I/O. Also supports Groovy. 🎱
  • Vert.x - Mature, fast, reactive and event-driven framework built on Netty engine for non-blocking I/O. Modular and supports numerous languages. Great community support and documentation. 🎱
  • Spark Java - Concise (micro-) framework for quickly creating Web APIs or web pages. Does not use annotations. Embeds the Jetty web server. 🎱

Tools

Tools to help upgrade your code to Java 8, generate code, or other utilities that don't become part of your codebase.

  • FreeBuilder - Writes builder-pattern builders for your code. Very well documented and supports all major IDEs and build tools. Supports Java 8 mapper methods.
  • Modernizer - Use this Maven plugin to find out what libraries you can get rid of and replace with Java 8 (and 7) built-in classes.

Books

I hesitated to add this, but with the restriction that these be real books and videos (as in, not a promotion or tied to a specific vendor of products), then let's see how this goes.

  • Java 8 in Action - One of the earlier Java 8 books, but has lots of good diagrams and pictures to help one learn about things like internal vs. external iteration in streams.
  • Java 8 Lambdas - Written by the author of the Lambda Behave testing framework, clearly Richard Warburton knows his lambdas. Concise, yet covers testing & debugging, design, and concurrency.
  • Java SE 8 for the Really Impatient - Cay S. Horstmann has been writing Java books forever. This book is right on target and includes even some of the "minor" new features in Java 8, such as using a lambda to do "compare-and-set" operations on atomic variables.
  • What's New in Java 8 - Free to read online, and includes lots of examples. Includes lambdas, streams, Nashorn (JavaScript engine), and the new Date/Time API.