Prev Next

Java / Java 21 Interview Questions

What are the key steps and pitfalls when migrating an application to Java 21?

Migrating from Java 8/11/17 to Java 21 requires attention to removed APIs, module system access restrictions, and the opportunity to adopt new features incrementally.

// Step 1: Compile with Java 21 — fix deprecation warnings
// javac --release 21 -Xlint:deprecation src/**/*.java

// Step 2: Run with Java 21 — look for startup warnings
// WARNING: Illegal reflective access ... (module access)
// Fix: add --add-opens flags until migrated properly

// Step 3: Scan for removed APIs
// - SecurityManager: remove System.setSecurityManager() calls
// - Thread.stop() / suspend() / resume(): use interrupt/flags
// - sun.* / com.sun.* internal APIs: use public replacements
// - Applet: remove entirely

// Step 4: Update dependencies
// Many libraries had Java 9+ compatibility issues that are now fixed
// Spring Boot 3.x requires Java 17+ and supports Java 21 natively
// Hibernate 6.x is Jakarta EE and Java 17+ compatible
// Jackson 2.15+ has module-info.java

// Step 5: Enable virtual threads (Spring Boot 3.2)
// spring.threads.virtual.enabled=true
// Then: remove thread pool sizing, increase load test concurrency

// Step 6: Replace synchronized with ReentrantLock in hot paths
// Use: jcmd  Thread.print to see pinned virtual threads

// Step 7: Adopt new language features incrementally
// Records -> DTO classes first
// Pattern matching instanceof -> existing instanceof+cast
// Text blocks -> multi-line strings (SQL, JSON, HTML)
// Switch expressions -> switch statements returning a value

// Step 8: Update GC selection
// G1 is still default and excellent
// Consider ZGC if latency percentiles matter and heap > 4 GB
Common Migration Pitfalls
PitfallSymptomFix
sun.misc.Unsafe usageInaccessibleObjectExceptionUse VarHandle or Cleaner API
Reflective access to internalsInaccessibleObjectException--add-opens or update library
Split packages across modulesModule resolution failureMerge JARs or use classpath
Thread.stop() removalNoSuchMethodErrorCooperative interrupt flag
synchronized + virtual threadsCarrier thread pinningReplace with ReentrantLock
High ThreadLocal usageMemory pressure at high VT countSwitch to ScopedValue
What is the primary configuration to enable virtual threads for HTTP request handling in Spring Boot 3.2?
Why does replacing 'synchronized' with 'ReentrantLock' matter for virtual thread performance?

Invest now in Acorns!!! 🚀 Join Acorns and get your $5 bonus!

Invest now in Acorns!!! 🚀
Join Acorns and get your $5 bonus!

Earn passively and while sleeping

Acorns is a micro-investing app that automatically invests your "spare change" from daily purchases into diversified, expert-built portfolios of ETFs. It is designed for beginners, allowing you to start investing with as little as $5. The service automates saving and investing. Disclosure: I may receive a referral bonus.

Invest now!!! Get Free equity stock (US, UK only)!

Use Robinhood app to invest in stocks. It is safe and secure. Use the Referral link to claim your free stock when you sign up!.

The Robinhood app makes it easy to trade stocks, crypto and more.


Webull! Receive free stock by signing up using the link: Webull signup.

More Related questions...

What is Java 21 and why is it a significant release? What are Virtual Threads in Java 21 and how do they differ from Platform Threads? How does Pattern Matching for switch work in Java 21? What are Record Patterns in Java 21 and how do they enable deconstruction? What are Sequenced Collections in Java 21? What are sealed classes and interfaces in Java and why are they important for pattern matching? What are Java Records and what do they automatically generate? What are Text Blocks in Java and how do you use them? What is Structured Concurrency in Java 21 and what problem does it solve? What are Scoped Values in Java 21 and how do they differ from ThreadLocal? What is Generational ZGC in Java 21 and why does it improve upon the original ZGC? What important String methods were added from Java 11 through Java 21? What is 'var' in Java and what are its limitations? What are switch expressions in Java and how do they differ from switch statements? How does pattern matching for instanceof work in Java 16+? What Stream API improvements were introduced in Java 9 through Java 21? How has Optional been improved and how should it be used correctly? How does CompletableFuture work in Java and how does it relate to virtual threads? What does the 'volatile' keyword guarantee in Java's memory model? What are the immutable collection factory methods introduced in Java 9? What are functional interfaces in Java and how are lambdas related to them? What are the most important Collectors and how do you write custom ones? What are Unnamed Classes and Instance Main Methods in Java 21 (Preview)? What improvements were made to NullPointerException messages in Java 14? How does type erasure affect instanceof checks with generics in Java? What are the differences between 'synchronized' and ReentrantLock in Java? What are the key classes in the java.time package and when do you use each? What garbage collectors are available in Java 21 and how do you choose between them? What is the Java Platform Module System (JPMS) and when should you use it? What are String Templates in Java 21 (Preview) and how do they improve string interpolation? What are the contracts for equals(), hashCode(), and Comparable in Java? What are the best practices for exception handling in Java? Why is immutability important in Java and how do you implement it correctly? What are default and static methods in Java interfaces? How does HashMap work internally in Java? How do virtual threads compare to reactive programming (Project Reactor / RxJava)? What is the Java 11 HttpClient and how do you use it for HTTP requests? What capabilities do Java enums have beyond simple named constants? What are the java.util.concurrent.atomic classes and how do they work? How does Java Reflection work and what are its performance implications? What are Unnamed Patterns and Variables in Java 21 (Preview) and how do they reduce boilerplate? When should you use StructuredTaskScope instead of CompletableFuture in Java 21? What major APIs were removed between Java 17 and Java 21? What are the most important JVM flags for tuning Java 21 application performance? What are the key steps and pitfalls when migrating an application to Java 21? How do Spring 7 and Spring Boot 4 optimize thread usage compared to older blocking models?
Show more question and Answers...

Spring

Comments & Discussions