System.out.println("Found: " + user), () -> System.out.println("Not found") ); // stream() — Java 9: use Optional in flatMap on a stream of Optionals List> opts = List.of(Optional.of("a"), Optional.empty(), Optional.of("b")); List present = opts.stream() .flatMap(Optional::stream) // ["a", "b"] .toList(); // ANTI-PATTERNS: // opt.isPresent() ? opt.get() : default -- use orElse(default) // Optional> -- use flatMap // Optional as a field -- use null or an explicit state enum // Optional as a parameter -- use method overloading"> System.out.println("Found: " + user), () -> System.out.println("Not found") ); // stream() — Java 9: use Optional in flatMap on a stream of Optionals List> opts = List.of(Optional.of("a"), Optional.empty(), Optional.of("b")); List present = opts.stream() .flatMap(Optional::stream) // ["a", "b"] .toList(); // ANTI-PATTERNS: // opt.isPresent() ? opt.get() : default -- use orElse(default) // Optional> -- use flatMap // Optional as a field -- use null or an explicit state enum // Optional as a parameter -- use method overloading" />

Prev Next

Java / Java 21 Interview Questions

How has Optional been improved and how should it be used correctly?

Optional<T> (Java 8) is a container for a value that may or may not be present. It is designed to be a return type that makes the absence of a value explicit in the API contract, not a replacement for null in all contexts.

Key Optional methods
MethodSincePurpose
of(T) / ofNullable(T) / empty()8Factory methods
isPresent() / isEmpty()8 / 11isEmpty() added Java 11
get() / orElse(T) / orElseGet(Supplier)8Extract value (orElseGet lazier)
orElseThrow(Supplier)8Throw custom exception if empty
map() / flatMap() / filter()8Transform the value
ifPresent(Consumer) / ifPresentOrElse()8 / 9ifPresentOrElse added Java 9
or(Supplier<Optional>)9Return this if present, else the supplied Optional
stream()9Returns Stream of 0 or 1 elements
// Correct use — as a return type
Optional findById(long id) {
    return Optional.ofNullable(repository.get(id));
}

// Chaining without get()
findById(42)
    .filter(u -> u.isActive())
    .map(User::email)
    .ifPresent(email -> sendNotification(email));

// or() — Java 9: fallback to another Optional
Optional user = findById(42)
    .or(() -> findByEmail("alice@example.com"));

// ifPresentOrElse — Java 9
findById(42).ifPresentOrElse(
    user -> System.out.println("Found: " + user),
    ()   -> System.out.println("Not found")
);

// stream() — Java 9: use Optional in flatMap on a stream of Optionals
List> opts = List.of(Optional.of("a"), Optional.empty(), Optional.of("b"));
List present = opts.stream()
    .flatMap(Optional::stream)  // ["a", "b"]
    .toList();

// ANTI-PATTERNS:
// opt.isPresent() ? opt.get() : default -- use orElse(default)
// Optional> -- use flatMap
// Optional as a field -- use null or an explicit state enum
// Optional as a parameter -- use method overloading
Which Optional method was added in Java 9 to provide a fallback Optional when the original is empty?
What is the recommended way to handle Optional in a flatMap over a stream of Optional values?

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