Something weird happened while I was debugging a Java program today. I had a simple program running with multiple threads, and I printed the thread names just to see what was happening. The output looked something like this: main http-nio-8080-exec-1 http-nio-8080-exec-2 ForkJoinPool.commonPool-worker-3 At first I ignored it. But then I started wondering… Where are all these threads actually coming from? I didn’t create them. After digging a bit deeper, I realized something interesting. Modern Java applications are constantly using different thread pools behind the scenes. For example: • The web server creates request threads • "CompletableFuture" uses the ForkJoinPool • Some frameworks create background worker threads • The JVM itself runs internal service threads Which means even a “simple” backend service may actually be running dozens of threads at the same time. It made me realize something: A lot of complexity in backend systems isn’t in the code we write — it’s in the systems running around our code. Now I’m a lot more curious about what’s actually happening inside the JVM when our apps run. #Java #BackendEngineering #SpringBoot #SoftwareEngineering #LearningInPublic
Java Thread Pools Behind the Scenes
More Relevant Posts
-
🚀 Sealed Classes + Records in Java — Clean Code or Just Hype? Java 17+ introduced Sealed Classes and Records, and honestly, together they solve two very real problems we’ve all faced: 👉 Uncontrolled inheritance 👉 Boilerplate-heavy data classes 🔒 Sealed Classes — Finally, Control Over Who Can Extend public sealed interface Payment permits CardPayment, UpiPayment {} This ensures: ✔️ Only defined types can implement your interface ✔️ No unexpected extensions ✔️ Safer and more predictable domain models 📦 Records — Say Goodbye to Boilerplate public record CardPayment(String cardNumber) implements Payment {} public record UpiPayment(String upiId) implements Payment {} ✔️ Immutable by default ✔️ No getters / constructors / equals / hashCode needed ✔️ Perfect for DTOs, APIs, event-driven systems ⚡ Together — This is Where It Gets Interesting Sealed → controlled hierarchy Record → immutable data switch(payment) { case CardPayment c -> System.out.println(c.cardNumber()); case UpiPayment u -> System.out.println(u.upiId()); } 💡 The compiler knows all possible types → fewer bugs, cleaner logic 🤔 Now I’m curious… Are you using sealed classes in your projects? Where exactly? Have records replaced your DTOs, or are you still relying on Lombok/classes? Any real-world challenges with Spring Boot, JPA, or serialization? 👇 Would love to hear how you’re using these features in production #Java #Java17 #SealedClasses #Records #CleanCode #JavaDeveloper #BackendDevelopment #SoftwareEngineering #Microservices #APIDesign #CodingBestPractices #TechDiscussion
To view or add a comment, sign in
-
-
🧠 JVM Memory & Garbage Collection Let me explain Java memory using your HOUSE as an example 🏠👇 🏠 JVM = Your House Your Java app lives here. Different rooms, different purposes. 📦 Heap = The Storeroom All objects go here. Never clean it? It crashes → OutOfMemoryError 💥 Heap has sections: 👶 Young Gen → new stuff (dies fast) 🧓 Old Gen → stuff you kept for years 🏷️ Metaspace → labels about your stuff 🪑 Stack = Your Desk Small, fast. Holds current work (method calls, local variables). Cleans itself when work is done. No GC needed! 🧹 Garbage Collection = Mom Cleaning Your Room “Do you still need this? No? GONE.” Java finds unused objects and removes them automatically. But sometimes GC yells: “EVERYBODY FREEZE while I clean!” ⏸️ These Stop-the-World pauses make apps laggy. 🔧 Choose Your Cleaner: 🟢 G1 → good all-rounder 🔵 ZGC → almost zero pauses 🟡 Shenandoah → low-latency beast 🔴 Serial → tiny apps only 📝 String Pool = Shared Notebook String a = “Hello”; String b = “Hello”; Java keeps ONE copy. Both point to it. Memory saved! 🎯 ⚡ Make Your App Faster: → Create only objects you need → Set unused objects to null → Close DB connections always → Remove unused listeners → Tune heap with -Xms and -Xmx → Profile with VisualVM or JConsole 🚨 Memory Leak Culprits: ❌ Unclosed DB connections ❌ Static lists that grow forever ❌ Listeners never unsubscribed ❌ Huge data in user sessions 🎯 Recap: 🏠 JVM = House 📦 Heap = Storeroom 🪑 Stack = Desk 🧹 GC = Auto cleaner 📝 String Pool = Shared notebook 🚨 Leaks = Stuff you forgot to toss Clean heap = Fast app 🏃💨 #Java #JVM #GarbageCollection #HeapMemory #JavaDeveloper #Programming #CodingTips #SoftwareEngineering #LearnJava #DevCommunity #100DaysOfCode #JavaPerformance #MemoryManagement #CleanCode #JavaInterview #BackendDevelopment
To view or add a comment, sign in
-
Day 1/100 — What is Java? ☕ Most beginners start writing Java code without understanding what actually runs their program. Let’s fix that today. When you write Java code, it doesn’t directly talk to Windows or Mac. First, the code is compiled into a bytecode (.class file) . This bytecode is then executed by the JVM (Java Virtual Machine). The JVM acts like a translator between your program and the operating system. That's the reason Java follows the famous principle: “Write Once, Run Anywhere.” JVM vs JRE vs JDK • JVM → Executes Java bytecode • JRE → JVM + standard libraries (String, Math, Collections, etc.) • JDK → JRE + developer tools like javac compiler 👉 If you're a developer, always install the JDK because it includes everything needed to build and run Java programs. Today's Challenge 1. Install the JDK 2. Create a file HelloWorld.java 3. Compile using: → javac HelloWorld.java 4. Run using: → java HelloWorld For More Clarity Check Out this Vedio:- https://lnkd.in/g4Tp5UMp Post your output screenshot in the comments — I’ll check it! 👇 hashtag #Java #100DaysOfJava #CoreJava #JavaDeveloper #Programming #LearnInPublic
To view or add a comment, sign in
-
-
💡 Java isn’t as simple as “new Object() = heap memory” Most developers learn: 👉 new Object() → Heap allocation 👉 Reference → Stack ✔️ Good for basics… but not the full story. 🚀 What really happens in modern Java? With JIT (Just-In-Time Compiler), the JVM can optimize away object creation completely. Yes, you read that right. void process() { Object obj = new Object(); System.out.println(obj.hashCode()); } 👉 If obj is used only inside the method and doesn’t “escape” ➡️ JVM may: Skip heap allocation ❌ Allocate on stack ⚡ Or eliminate the object entirely 🔥 🧠 The core concept: Escape Analysis If an object: ❌ Does NOT leave the method → Optimized ✅ Escapes (returned, shared, stored) → Heap allocation ⚠️ Common misconception ❌ “Avoid creating objects to save memory” ✔️ Reality: JVM is smarter than that Premature optimization can: Make code ugly Reduce maintainability Give no real performance gain 🔧 Static vs Object? ✔️ Use static when no state is needed ✔️ Use objects when behavior depends on data 👉 It’s not about avoiding new 👉 It’s about writing clean, logical design 🏁 Final takeaway Java is not just compiled — it adapts at runtime 🔥 The JVM decides: What to allocate What to remove What to optimize 👨💻 Write clean code. 📊 Measure performance. ⚡ Trust the JVM. #Java #JVM #Performance #Backend #SoftwareEngineering #CleanCode
To view or add a comment, sign in
-
Dev Notes #05 Strings in Java don't change. They just pretend to. I was dry running a piece of code. Two strings. One lowercase, one upper. 𝚂𝚝𝚛𝚒𝚗𝚐 𝚜𝟷 = "𝚑𝚎𝚕𝚕𝚘"; 𝚂𝚝𝚛𝚒𝚗𝚐 𝚜𝟸 = "𝙷𝙴𝙻𝙻𝙾"; 𝚜𝟸.𝚝𝚘𝙻𝚘𝚠𝚎𝚛𝙲𝚊𝚜𝚎(); 𝚒𝚏 (𝚜𝟷 == 𝚜𝟸) // 𝚠𝚒𝚕𝚕 𝚝𝚑𝚒𝚜 𝚎𝚟𝚎𝚛 𝚋𝚎 𝚝𝚛𝚞𝚎? My first instinct, "Yeah they should match" That was my carelessness if anything, They didn't. And they never will. Here's what's actually happening: 𝚜𝟸.𝚝𝚘𝙻𝚘𝚠𝚎𝚛𝙲𝚊𝚜𝚎(); doesn't modify 𝚜𝟸. It creates a brand new String object and throws it away because nobody caught it. 𝚜𝟸 is still "𝙷𝙴𝙻𝙻𝙾", completely unbothered. The fix is as follows: 𝚜𝟸 = 𝚜𝟸.𝚝𝚘𝙻𝚘𝚠𝚎𝚛𝙲𝚊𝚜𝚎(); Strings are immutable. Every method you call on them returns a new object. The original never changes. Immutability makes Strings safe to share across threads, safe to use as HashMap keys, and predictable in behavior. And yes, one more thing, Even after the fix, 𝚜𝟷 == 𝚜𝟸 is still the wrong comparison. == checks if both variables point to the same object in memory. .𝚎𝚚𝚞𝚊𝚕𝚜() checks if they hold the same value. 𝚜𝟸 = 𝚜𝟸.𝚝𝚘𝙻𝚘𝚠𝚎𝚛𝙲𝚊𝚜𝚎(); 𝚜𝟷 == 𝚜𝟸 // 𝚏𝚊𝚕𝚜𝚎 (𝚍𝚒𝚏𝚏𝚎𝚛𝚎𝚗𝚝 𝚘𝚋𝚓𝚎𝚌𝚝𝚜) 𝚜𝟷.𝚎𝚚𝚞𝚊𝚕𝚜(𝚜𝟸) // 𝚝𝚛𝚞𝚎 (𝚜𝚊𝚖𝚎 𝚟𝚊𝚕𝚞𝚎) Two separate lessons hiding inside one silly mistake. Was truly a facepalm moment for me this time. Did such events ever happen to you? #Java #DevNotes #LearningInPublic #SpringBoot #BackendDevelopment
To view or add a comment, sign in
-
I’ve written a simple blog breaking down the real difference between blocking, parking, and virtual threads in Java — and explaining what exactly gets paused (OS thread vs continuation) when your code “waits.” https://lnkd.in/g5DxUNMW
To view or add a comment, sign in
-
Method Overriding in Java - where polymorphism actually shows its power Method overriding happens when a subclass provides its own implementation of a method that already exists in the parent class. For overriding to work in Java: • The method name must be the same • The parameters must be the same • The return type must be the same (or covariant) The key idea is simple: The method that runs is decided at runtime, not compile time. This is why method overriding is called runtime polymorphism. Why does this matter? Because it allows subclasses to modify or extend the behavior of a parent class without changing the original code. This is a core principle behind flexible and scalable object-oriented design. A small keyword like @Override might look simple, but the concept behind it is what enables powerful design patterns and extensible systems in Java. Understanding these fundamentals makes the difference between just writing code and truly understanding how Java works. #Java #JavaProgramming #OOP #BackendDevelopment #CSFundamentals
To view or add a comment, sign in
-
-
Day 7 of #100DaysOfCode — Java is getting interesting ☕ Today I explored the Java Collections Framework. Before this, I was using arrays for everything. But arrays have one limitation — fixed size. 👉 What if we need to add more data later? That’s where Collections come in. 🔹 Key Learnings: ArrayList grows dynamically — no size worries Easy operations: add(), remove(), get(), size() More flexible than arrays 🔹 Iterator (Game changer) A clean way to loop through collections: hasNext() → checks next element next() → returns next element remove() → safely removes element 🔹 Concept that clicked today: Iterable → Collection → List → ArrayList This small hierarchy made everything much clearer. ⚡ Array vs ArrayList Array → fixed size ArrayList → dynamic size Array → stores primitives ArrayList → stores objects Still exploring: Set, Map, Queue next 🔥 Consistency is the only plan. Showing up every day 💪 If you’re also learning Java or working with Collections — let’s connect 🤝 #Java #Collections #ArrayList #100DaysOfCode #JavaDeveloper #LearningInPublic
To view or add a comment, sign in
-
💻 Modern Java Tricks I Actually Use to Save Time After 4 years working with Java, I realized: being a “senior” isn’t just about design patterns or DSA. It’s about knowing which language features cut down boilerplate. Even in 2025, I see teams still writing Java 8-style code: 20+ line DTOs Nested null checks everywhere Blocking futures slowing things down Switch statements that bite you with fall-through bugs Java 17–21 gives us tools to fix all that without extra lines of code. Some of my go-to features: Records → goodbye huge data classes Sealed Classes → safer type hierarchies Pattern Matching → no more casting headaches Switch Expressions → no accidental fall-throughs Text Blocks → clean SQL/JSON/HTML in code var → less noise, same type safety Streams + Collectors → readable pipelines Optional properly → avoid NPEs CompletableFuture → async calls made simple Structured Concurrency → async the modern way These aren’t just features—I’ve used them in real projects to write faster, cleaner code. 👇 Curious: which Java version is your team on? Drop a comment—I’ll reply to everyone. 🔁 If you know a teammate who still writes Java 8 style, share this with them. #Java #Java21 #SpringBoot #CleanCode #BackendEngineering #SoftwareDevelopment
To view or add a comment, sign in
-
String is easily the most-used type in any #Java codebase. For the most part, we don't need to think about it, and most of the time, we don't have to. But over the last decade, the java.lang.String class has quietly evolved into an architectural marvel. My latest article covers the design decisions behind Java's most common class and how it actually works under the hood today. A few things covered in the post: • Why CHarSequence is an elegant abstraction. • Why a single emoji can silently double a string's memory footprint (and how Compact Strings work). • Why the classic advice to "always use StringBuilder instead of the + operator" is no more universally true in modern Java. • The String.intern() trap, and why G1 string deduplication mostly solved it. • A look at the modern API highlights you might have missed. If you've ever tracked a memory issue or GC thrashing down to massive char arrays in a heap dump, this one might interest you. Read "The Secret Life of a Java String" on Medium here: https://lnkd.in/evWjh9Kx
To view or add a comment, sign in
Explore content categories
- Career
- Productivity
- Finance
- Soft Skills & Emotional Intelligence
- Project Management
- Education
- Technology
- Leadership
- Ecommerce
- User Experience
- Recruitment & HR
- Customer Experience
- Real Estate
- Marketing
- Sales
- Retail & Merchandising
- Science
- Supply Chain Management
- Future Of Work
- Consulting
- Writing
- Economics
- Artificial Intelligence
- Employee Experience
- Workplace Trends
- Fundraising
- Networking
- Corporate Social Responsibility
- Negotiation
- Communication
- Engineering
- Hospitality & Tourism
- Business Strategy
- Change Management
- Organizational Culture
- Design
- Innovation
- Event Planning
- Training & Development