Java Stream API: Intermediate and Terminal Operations Explained

🚀 Java Stream API — Simplify Your Data Processing Stream API (introduced in Java 8) helps us process collections in a declarative, functional-style way — reducing boilerplate and improving readability. Let’s explore the two types of Stream operations 👇 ✅ Intermediate Operations ✅ Terminal Operations 🔹 Intermediate Operations (Lazy — return another Stream) filter() → filters elements based on condition map() → transforms each element flatMap() → flattens nested structures sorted() → sorts elements distinct() → removes duplicates limit(n) → takes first n elements skip(n) → skips first n elements peek() → used for debugging (prints intermediate values) takeWhile() → takes elements while condition is true (Java 9+) dropWhile() → skips elements while condition is true (Java 9+) 💡 Intermediate operations are lazy — they don’t execute until a terminal operation is called. 🔹 Terminal Operations (Eager — produce a final result) forEach() → performs an action on each element collect() → collects result into List, Set, or Map count() → returns number of elements reduce() → combines elements into one result findFirst() → returns the first element findAny() → returns any element (useful in parallel streams) anyMatch() → returns true if any element matches condition allMatch() → returns true if all match condition noneMatch() → returns true if none match condition toArray() → returns an array of elements min() / max() → returns smallest/largest element based on comparator 💡 Once a terminal operation is executed, the stream is consumed and can’t be reused. 📘 Quick Summary Intermediate → Transform or filter Terminal → Produce result & close stream Stream can’t be reused after a terminal operation 💬 How often do you use Stream API in your daily coding? Comment your favorite Stream method below 👇 #Java #StreamAPI #Java8 #FunctionalProgramming

To view or add a comment, sign in

Explore content categories