There is quiet change in Java that every Java Developer should know about👀 I still remember the first Java program I ever wrote like every beginner, I memorized this line like a ritual : `public static void main(String[] args)` But here’s the surprising part In modern Java (21+), you can now write: void main() { System.out.println("Hello World"); } Yes… no `static`. 😮 So what actually changed? **Old JVM behaviour** When a Java program starts: 1️⃣ JVM loads the class 2️⃣ No objects exist yet 3️⃣ JVM looks for a method it can call directly Since non-static methods need an object, Java forced us to use a static `main()`. That’s why we all memorized that signature. But in Modern JVM behavior (Java 21 → 25) JVM quietly does this behind the scenes: ```java new Main().main(); ``` It creates the object and calls the method for you. This change actually pushes Java closer to being more object-oriented, because now your program can start from an instance method instead of a static one. Next time, let’s discuss a fun debate Why Java is still NOT a 100% Object-Oriented language. Did you know this change already happened? #Java #Programming #JVM #SoftwareEngineering #Developers
Java's Quiet Change: No Static Main Method Required
More Relevant Posts
-
Most Java developers have seen this line countless times: private static final long serialVersionUID = 1L; …but why does it exist? The serialVersionUID is a version identifier used during Java serialization. When an object is serialized, the JVM stores this UID together with the object’s data. Later, during deserialization, Java compares the UID in the file with the UID of the current class. If they don’t match, a InvalidClassException is thrown. In other words, the UID is a compatibility contract between serialized data and the class definition. A few practical insights: - Adding a new field doesn't require changing the UID, because missing fields receive default values during deserialization, keeping backward compatibility. - Removing fields, changing field types, or modifying class hierarchy breaks compatibility and requires a UID change. - If the serialVersionUID is omitted, the JVM generates one automatically based on the class structure. However, a new UID will be generated even if compatible changes are made (such as adding a field), unnecessarily making all previously serialized objects unreadable. That’s why many projects explicitly declare: private static final long serialVersionUID = 1L; It simply means: this is version 1 of the serialized form of this class. Serialization is one of those Java features that looks simple but hides important design decisions about backward compatibility and data evolution. Have you ever run into a mysterious InvalidClassException in production? #Java #Serialization #SoftwareEngineering
To view or add a comment, sign in
-
📌Exception Handling in Java ⚠️ ✅Exception Handling is a mechanism to handle unexpected situations that occur while a program is running. When an exception occurs, it disrupts the normal flow of the program. Common examples: • Accessing an invalid index in an array→ ArrayIndexOutOfBoundsException • Dividing a number by zero→ ArithmeticException Java provides thousands of exception classes to handle different runtime problems. 📌 Types of Exceptions in Java 1️⃣ Built-in Exceptions These are predefined exceptions provided by Java. ✅Checked Exceptions -Checked by the compiler at compile time Must be handled using try-catch or declared using throws Examples: IOException SQLException ClassNotFoundException ✅Unchecked Exceptions -Not checked by the compiler at compile time Occur mainly due to programming errors Examples: ArithmeticException NullPointerException ClassCastException 2️⃣ User-Defined (Custom) Exceptions Java also allows developers to create their own exceptions. This is useful when we want to represent specific business logic errors. Basic rules to create a custom exception: 1️⃣ Extend the Exception class 2️⃣ Create a constructor with a message 3️⃣ Throw the exception using throw 4️⃣ Handle it using try-catch 📌 Finally Block ✅The finally block always executes after the try-catch block, whether an exception occurs or not. It is commonly used for cleanup tasks, such as: Closing database connections Closing files Releasing resources 📌 Try-With-Resources ✅Sometimes developers forget to close resources manually. To solve this problem, Java introduced Try-With-Resources. It automatically closes resources once the block finishes execution. This makes resource management safer and cleaner. 📌 Important Keywords ✅throw : Used to explicitly create and throw an exception object. ✅throws: Used in the method signature to indicate that a method may throw an exception. Grateful to my mentor Suresh Bishnoi Sir for explaining Java concepts with such clarity and practical depth . If this post added value, feel free to connect and share it with someone learning Java. #Java #ExceptionHandling #CoreJava #JavaDeveloper #BackendDevelopment #SoftwareEngineering #InterviewPreparation #JavaProgramming #CleanCode
To view or add a comment, sign in
-
-
One of Java’s Most Powerful Concepts: Immutability - Many developers use String every day in Java… but few realize why it’s immutable. Example: String name = "Java"; name.concat(" Developer"); System.out.println(name); Output: Java Even though we tried to modify it, the value did not change. Why? Because String objects in Java are immutable. Whenever you modify a String, Java actually creates a new object instead of changing the existing one. Example: String name = "Java"; name = name.concat(" Developer"); System.out.println(name); Output: Java Developer Why Java designed it this way? Immutability helps with: 🔒 Security (important for class loading & networking) ⚡ Performance (String Pool optimization) 🧵 Thread Safety (no synchronization required) This small design decision is one of the reasons Java remains powerful for enterprise systems. ☕ Lesson: Great developers don't just write code… they understand why the language works the way it does. 💬 Question for developers: Which Java concept took you the longest time to understand? #Java #JavaDeveloper #Programming #BackendDevelopment #CleanCode #SoftwareEngineering
To view or add a comment, sign in
-
🚀 Java Revision Journey – Day 13 Today I revised two important Java concepts that help in understanding how Java programs execute and how modern Java makes code cleaner and more expressive. 📝Method Call Stack in Exceptions The Method Call Stack in Java manages method execution during runtime. Whenever a method is called, Java creates a stack frame and pushes it onto the call stack. When the method finishes execution, the frame is removed. 📌 When an exception occurs, Java starts searching upward through the call stack to find a matching catch block. If no matching handler is found, the program terminates and a stack trace is printed. This concept helps developers to: Understand exception propagation Identify where the exception originated Debug runtime errors using stack trace information Understanding the call stack is essential for diagnosing issues and writing reliable Java applications. 💻 Java Method References I also revised Method References, a feature introduced in Java 8 that provides a cleaner and shorter alternative to lambda expressions. A method reference allows referring to an existing method without executing it, using the :: operator. It improves readability and reduces boilerplate code when a lambda simply calls an existing method. 📍 Types of Method References in Java 1️⃣ Reference to a Static Method ClassName::staticMethodName 2️⃣ Reference to an Instance Method of a Particular Object objectReference::instanceMethod 3️⃣ Reference to an Instance Method of an Arbitrary Object ClassName::instanceMethod 4️⃣ Reference to a Constructor ClassName::new 🔖 Method References and Functional Interfaces Method references work only with Functional Interfaces (interfaces with exactly one abstract method). Important points: Method signature must match the functional interface method Common functional interfaces include Consumer, Supplier, Function, and Predicate Frequently used with Streams and Collections API 📌 Learning concepts like Exception Call Stack and Method References helps in understanding how Java works internally while also writing cleaner, more modern Java code. Step by step, continuing to strengthen my Java fundamentals and deepening my understanding of the language. #Java #JavaLearning #JavaDeveloper #Java8 #MethodReference #ExceptionHandling #OOP #BackendDevelopment #Programming #JavaRevisionJourney 🚀
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
-
-
Most developers believe that a Java program can only have one "main()" method, but this isn't entirely accurate. A Java class can indeed contain multiple "main()" methods through method overloading, provided their parameter lists differ. However, the Java Virtual Machine (JVM) will only initiate execution from this specific method signature: "public static void main(String[] args)". Any additional "main()" methods will not execute automatically; they must be invoked manually from the original "main()" method. For example: public class Test { public static void main(String[] args) { System.out.println("Original main method"); main(10); } public static void main(int a) { System.out.println("Overloaded main method: " + a); } } In conclusion, while multiple "main()" methods are permissible, the JVM recognizes only one entry point. #Java #Programming #JavaDeveloper #JavaInterview #BackendDevelopment
To view or add a comment, sign in
-
-
☕ #ThinkingInJava — Post No. 2 Building deeper Java understanding, one concept at a time. 👉 What made me revisit this? While exploring Java file structure, I had a follow-up curiosity: if multiple classes can exist in one file, what happens to the main() method? Where should it live, and which one runs? 👇 💡 Java Concept — Multiple classes & main() behavior Java allows flexibility in structuring classes inside a file, but execution behavior is very explicit and runtime-driven. ✅ Core Rules / Facts • A Java file can contain multiple classes, but at most one can be public • The main() method does not have to be inside the public class • You can define main() in any class within the file • If multiple classes contain main(), none runs automatically • JVM executes only the class explicitly specified at runtime (or selected in IDE) 🎯 Interview One-liner 👉 In Java, the main() method can exist in any class, and when multiple entry points exist, the JVM runs only the class explicitly invoked. 🧠 Why this matters in real projects Understanding entry-point behavior helps while debugging multi-class utilities, running POCs, and organizing automation helpers that may contain independent executable code. 🔖 Takeaway Execution in Java is explicit → Structure is flexible → Clarity comes from understanding entry points hashtag #Java #AutomationSpecialist #TestAutomation
To view or add a comment, sign in
-
🚀 Top 5 Modern Features in Java Every Developer Should Know Java has evolved significantly over the past few years. The language that once felt verbose is now becoming more concise, expressive, and developer-friendly. Here are 5 powerful modern features in Java that every developer should explore: 🔹 1. Records (Java 16) Records provide a compact way to create immutable data classes. No need to write boilerplate code like getters, constructors, "equals()", or "hashCode()". 🔹 2. Pattern Matching for "instanceof" Java simplified type checking and casting. You can now test and cast in a single step, making code cleaner and easier to read. 🔹 3. Switch Expressions The traditional switch statement is now more powerful and concise. It supports returning values and eliminates unnecessary "break" statements. 🔹 4. Text Blocks Writing multi-line strings (like JSON, SQL queries, or HTML) is much easier with text blocks using triple quotes. 🔹 5. Virtual Threads (Project Loom – Java 21) A major breakthrough for concurrency. Virtual threads allow you to create thousands or even millions of lightweight threads, making scalable applications easier to build. 💡 Java is no longer just about stability — it’s evolving fast with modern developer needs. Staying updated with these features can significantly improve code readability, performance, and productivity. #Java #SoftwareDevelopment #Programming #Developers #TechInnovation #JavaDeveloper
To view or add a comment, sign in
-
Ever wondered why the Java entry point looks exactly like this? ☕️ If you’re a Java dev, you’ve typed public static void main(String[] args) Thousands of times. But why these specific keywords? Let’s break down the "magic" formula: public: The JVM needs to access this method from outside the class to start the program. If it were private, the "engine" couldn't turn the key. static: This is the big one. The JVM needs to call the main method before any objects of the class are created. Without static, you’d have a "chicken and egg" problem. void: Once the program finishes, it simply terminates. Java doesn't require the method to return a status code to the JVM (unlike C++). String[] args: This allows us to pass command-line arguments into our application. Even if you don't use them, the JVM looks for this specific signature. Understanding the "Why" makes us better at the "How." #Java #Programming #SoftwareEngineering #Backend #CodingTips
To view or add a comment, sign in
-
-
NullPointerException — the most famous Java error every developer meets at least once. You write the code. You compile it. You run it with confidence. And then Java says: Exception in thread "main" java.lang.NullPointerException What happened? Your code expected an object… but Java found nothing. In simple words: Developer: “Use this object.” Java: “Which object? There is nothing here.” And boom 💀 Every Java developer has faced this moment at least once. The real lesson? Always check for null values, initialize objects properly, and understand how references work in Java. Because sometimes the problem isn't the code… It's the missing object behind the reference. Be honest 👀 How many times has NullPointerException ruined your day? #Java #JavaDeveloper #Programming #SoftwareDevelopment #Coding #Developers #Tech #BackendDevelopment #LearnJava #CodingLife
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