There’s much more to a new Java release than the well-known JEPs.
Class loaders are the key to understanding how the JVM executes programs.
Complex analysis of variables’ scope enables a variety of subtle optimizations.
How adding lazy operations to ArrayList and HashMap improved performance and reduced memory usage
How annotations work, how best to use them, and how to write your own
For years, some important articles have not been available on the magazine website. They are now.
The need to encapsulate the runtime is fundamentally caused by Java’s nature as an open programming environment.
Java Champions love pattern matching for instanceof, records, Stream.toList(), the vector API, the foreign linker API, and the foreign-memory access API.
Information from the Oracle Java Platform Group and from Java Magazine
The Java Champions say these are a few of their favorite things.
The invokedynamic instruction added in Java 7 makes it possible to resolve method calls dynamically at runtime.
Porting Java to the AArch64 architecture is a JEP 388 success story.
Special bytecodes make calling methods particularly efficient. Knowing how they operate reveals how the JVM executes your code.
How false sharing and branch misprediction can have unwanted effects on your code’s performance
You can understand application performance—and optimize your software approach—by understanding how CPUs, memory, and caches affect execution.
See how virtual threads bring back the old days of Java’s green threads—that is, Java threads not tied to operating-system threads.
Look into the bytecode to see how Java handles lambdas.
When Java shows up at a party, it always brings a delicious dessert.
Just because you can break the rules, doesn’t mean you should break the rules—unless you have a good reason.
Get a stream of high-volume data points about your running app.