The Java Cafe

The Java Cafe is a community of amazing users

Java and Cloud content, by the community for the community

Create new account Log in
loading...

How to Build Java Applications Today: April 19, 2021

ksilz profile image Karsten Silz Originally published at bpfnl.substack.com ・8 min read

TLDR

I’m a JJUG CCC Spring speaker, Oracle’s Java architect panel, IBM joins Eclipse Adoptium, Java AOT compilation beyond GraalVM, down to 4 smartphone vendors, and Spring Spring Boot 2.3.10 & 2.4.5.


README

This is issue 32 of my weekly newsletter, “How To Build Java Applications Today”. I read all the Java newsletters, so you don’t have to! And I try to entertain you while presenting the news.

If you like my newsletter, then subscribe to it on Substack!


Quote of the Week

We have two lives, and the second begins when we realize we only have one.‌
Confucius, Chinese philosopher (551–479 BCE)


Stand-Up

What can I say: Another Java conference picked up my talk “How Should Java Developers Build Front-Ends for Web, Mobile & Desktop Today”. This time, it’s the Japan Java User Group with their spring conference. The schedule isn’t out yet, but I hope the time difference won’t be mean to me!

My second InfoQ news article got published. It’s a topic that I know well: JHipster 7.0. I’m working on my third article already.


Code Review

Issue 31 from April 12, 2021

Last week’s issue had some embarrassing mistakes: The version sent by mail had the wrong date in the title and a typo in the summary. That’s what happens when you start writing a newsletter too late in the evening. Or when you don’t have an editor. Or both.

Anyhow, I hope this week’s issue turns out better. At least, I started writing earlier this time around!


Bookmarks

Java

How Do Oracle’s Java Architects Want to Combat Java’s Slide in Popularity?

In the TIOBE Index for April 2021, Java lost a third of its popularity year-over-year, barely clinging to second place ahead of surging Python (see issue 30 from April 5, section “TIOBE Index April 2021”). In the quarterly “RedMonk Programming Language Rankings”, Java’s in third place already, behind JavaScript and Python. It dropped to that place in Q2/2020 (see issue 26 from March 8, section “RedMonk Programming Language Rankings Q1/2021”).

Oracle recently got its Java Architects together for a panel discussion: Mark Reinhold (Chief Architect), Brian Goetz (Chief Language Architect), Mikael Vidstedt (Group Director Software Development), and Ron Pressler (Consulting Member of Technical Staff). So, what did they have to say about that slide in popularity? Unfortunately, not much. And their plan won’t move the needle anytime soon.

Mark Reinhold isn’t much help here. He puts up a so-called “straw man”: A false argument that’s easier to beat than your opponent’s real argument. Mark says that the popularity of languages is measured by downloads and that he doesn’t believe in these statistics (time-coded YouTube link). Mr Reinhold, happy to correct you: It’s search engine queries for TIOBE, questions on Stack Overflow and pull requests on Github for RedMonk. And then Mark says he likes developer surveys more. Fair enough. But then he doesn’t cite any that put Java up against other languages.

Fortunately, Ron Pressler is more helpful (time-coded YouTube link): He wants Java to stay in the top 3 or 4. Well, that’s a word. He thinks that the upcoming changes in Java, like Project Loom and Project Valhalla, will help, but more is needed.

Here’s the problem: It could be five years before these “upcoming changes in Java” make a dent in TIOBE or RedMonk. Why’s that?

To change Java slide in popularity, developers first need to experience changes for the better in Java. Then they need to use Java more. And finally, TIOBE and RedMonk need to pick up on these changes in Java adoption. That’s two years right there.

But most of us Java developers won’t see these “changes for the better” in Java for years to come. Heck, most of us are still on Java 8: JRebel says it’s 69% (issue 27 from March 15, section “JRebel 2021 Java Technology Report”), Snyk pegged it at 64% way back in February 2020 (the 2021 report isn’t done yet). And the adoption of Java 12-16 remains limited.

And these changes that Oracle talks about? They won’t be in Java 17. So even if developers move off of Java 8, most will only get these changes with Java 23 in 2024. That’s the next LTS release after Java 17, the upcoming LTS release this September. When we add the two years from above for Java 23 changes to ripple through the Java ecosystem, we’re talking late 2026 for seeing results in TIOBE and RedMonk. That’s a long time for Java to slide! Let’s hope Java’s still in the top 4 by then. 😓

YouTube video


IBM Joins Eclipse Adoptium To Publish OpenJ9 Binaries

AdoptOpenJDK distributes JDK binaries for the Oracle Hotspot JVM and the Eclipse OpenJ9 JVM. OpenJ9 originated with IBM but was open-sourced to the Eclipse foundation four years ago.

When AdoptOpenJDK moved to Eclipse to become Adoptium (see issue 29 from March 29, section “AdoptOpenJDK Gets Eclipse Working Group and Access to TCK”), they accepted Oracle’s terms that forbade them to ship OpenJ9 binaries.

Let me get this straight: A non-Eclipse project moves to Eclipse and can’t ship binaries for another Eclipse project anymore. Isn’t it ironic, don’t you think?

So, where does one get OpenJ9 binaries in the future?

IBM wouldn’t be IBM if it didn’t know a way out of this conundrum: Money. IBM just joined Eclipse Adoptium as an enterprise member and can now offer “free certified JDKs with Eclipse OpenJ9”. Problem solved!

Announcement blog post


Java Ahead-of-Time Compilation Beyond GraalVM?

Unless you’ve lived under a rock for the last year or two, you’ve probably heard of GraalVM. Using so-called Ahead-of-Time Compilation (AOT), it produces native images for our Java programs that use much less memory and start much faster. Spring Boot will support this out of the box this fall (see issue 28 from March 22, section “Kicking Spring Native's Tires”). And the competitors of Spring Boot, like Quarkus and Micronaut, have long supported GraalVM.

Are there other AOT options beyond GraalVM? Yes, but we’re best served by GraalVM. Still, what are those options?

First up is Project Leyden, an OpenJDK initiative. It wants to standardize what GraalVM does: Fix the “slow start-up time, the slow time to peak performance, and the large footprint of Java applications”. How? When? With whom? We don’t know: The expert group working on Project Leyden hasn’t formed yet. Is this another “Java module system” - an unnecessary recreation of an existing, good-enough solution? Only time will tell.

Checkpoint Restore in User Space (CRIU) is here today. It allows us to save a snapshot of a running Linux process and restore it later. That takes care of Java’s slow start-up time but doesn’t fix the memory footprint or the time to peak performance.

Finally, the presenter counts frameworks like Quarkus or Micronaut as another set of options. But they use GraalVM under the hood, so to me, they don’t count.

InfoQ presentation


Over The Fence

We’re Down To Four Smartphone Vendors

Smartphones are the most used computer to consumers everywhere and become increasingly important in the enterprise. So it’s a good thing that there are so many vendors to choose from. Right. Right?

Wrong: There are only four important smartphone vendors left. Who are they?

You probably guessed Apple and Samsung. Then there’s the popular Chinese brand Xiaomi. And finally, we have BBK. BB what? Yeah, I hadn’t heard of them either. It’s a Chinese company that owns Vivo, Oppo, RealMe, and OnePlus. Ok, but where’s everybody else?

LG just recently quit. Sony could be next. And the Chinese vendor Huawei is hit hard by US sanctions and already sold off its secondary phone business.

We’re at least better off with four vendors than in the early 2000s: Just three vendors dominated phone sales back then. Which ones? Read the article to find out! A hint: In a sign of European technology decline, two of the three were from Europe. Scandinavia, to be more precise. Well, now I made it too easy, I think!

News article


Releases

Spring Boot 2.3.10 & 2.4.5

To all of you Spring Boot developers out there: It’s time to upgrade! Spring Boot 2.4.5 has 57 bug fixes, documentation improvements, and dependency upgrades, Spring Boot 2.3.10 has 78.

Announcement 2.3.10, announcement 2.4.5


About

Karsten Silz is the author of this newsletter. He is a full-stack web & mobile developer with 22 years of Java experience, author, speaker, and entrepreneur. Karsten got a Master's degree in Computer Science at the Dresden University of Technology (Germany) in 1996.

Karsten has developed software in five European countries and the US. In 2004, he co-founded a software product start-up in the US. During power outages, the software protected TV, Internet, and phone services for 50 million North American cable TV households. Karsten led product development for 13 years and left after the company was sold successfully.

Karsten has worked as a contractor since 2017. He co-founded the UK SaaS start-up "Your Home in Good Hands" as CTO in 2020.

Karsten has this newsletter, a developer website, and a contractor site. He's on LinkedInTwitter, and GitHub.

Discussion (0)

pic
Editor guide