The Command Pattern in Java: Eliminating Fat Service Classes with Commands and Handlers Fat Service classes are a liability — one class that does everything is a class that's impossible to test and dangerous to change. This post shows how to apply the Command pattern in Java using Records, Repository interfaces, and single-responsibility Handlers to keep your business logic clean and isolated....
Sergio Lema 🧑🏻💻’s Post
More Relevant Posts
-
The Command Pattern in Java: Eliminating Fat Service Classes with Commands and Handlers Fat Service classes are a liability — one class that does everything is a class that's impossible to test and dangerous to change. This post shows how to apply the Command pattern in Java using Records, Repository interfaces, and single-responsibility Handlers to keep your business logic clean and isolated....
To view or add a comment, sign in
-
Learn how to use Java Records to simplify data modeling with immutable data, automatic method generation, and concise syntax in your apps.
To view or add a comment, sign in
-
Learn how to use Java Records to simplify data modeling with immutable data, automatic method generation, and concise syntax in your apps.
To view or add a comment, sign in
-
💅 Java Collections Framework — Complete Roadmap => One of the most important topics every Java developer must master is the Java Collections Framework (JCF). From List, Set, Queue, and Map to classes like ArrayList, HashMap, LinkedList, TreeMap, and PriorityQueue — understanding when and why to use each collection can make your code cleaner, faster, and more efficient. 👉 Prior to Java 2, Java provided ad hoc classes such as Dictionary, Vector, Stack, and Properties to store and manipulate groups of objects. Although these classes were quite useful, they lacked a central, unifying theme. Thus, the way that you used Vector was different from the way that you used Properties. #What is Java Collections Framework? -> A collections framework is a unified architecture for representing and manipulating collections. All collections frameworks contain the following: -> Interfaces − These are abstract data types that represent collections. Interfaces allow collections to be manipulated independently of the details of their representation. In object-oriented languages, interfaces generally form a hierarchy. -> Implementations, i.e., Classes − These are the concrete implementations of the collection interfaces. In essence, they are reusable data structures. -> Algorithms − These are the methods that perform useful computations, such as searching and sorting, on objects that implement collection interfaces. The algorithms are said to be polymorphic: that is, the same method can be used on many different implementations of the appropriate collection interface. -> In addition to collections, the framework defines several map interfaces and classes. Maps store key/value pairs. Although maps are not collections in the proper use of the term, but they are fully integrated with collections. 👉 In this roadmap, I covered: ✔ Collections hierarchy ✔ Important classes & interfaces ✔ Time complexities ✔ Best use cases ✔ Beginner tips Save this for your Java journey 🔖 Which Java collection do you use the most? 👇 #Java #JavaCollections #JCF #CollectionsFramework #Programming #Developers #Coding #BackendDevelopment #DSA #SoftwareEngineering
To view or add a comment, sign in
-
-
Since Java 10, Java introduced a handy feature called var that allows the compiler to infer the type of local variables from their initializer, making code easier to read. // Without var String name = "Java"; URL url = new URL("http://google.com"); // With var var name = "Java"; var url = new URL("http://google.com"); Here are the best way to use it: Use var when: • The type is obvious from the constructor: var list = new ArrayList<String>(); (No need to write ArrayList<String>() twice) • Handling complex generics: Prefer: var map = new HashMap<String, List<Order>>(); than: Map<String, List<Order>> map = new HashMap<String, List<Order>>(); • The variable name provides enough context: var customer = service.findCustomerById(id); (The name customer tells what it is) Avoid var when: • The initializer is not obvious: var result = o.calculate(); (Hard to tell if result is an int, a double or a Result object...) • The variable has a long scope: if a method is 50 lines long, using var at the top makes it harder to remember the type when reaching the bottom. • Using var in method signatures (not allowed anyway): Java only allows var for local variables, not fields, parameters, or return types.
To view or add a comment, sign in
-
Java is quietly becoming more expressive This is not the Java you learned 5 years ago. Modern Java (21 → 25) is becoming much more concise and safer. 🧠 Old Java if (obj instanceof User) { User user = (User) obj; return user.getName(); } else if (obj instanceof Admin) { Admin admin = (Admin) obj; return admin.getRole(); } 👉 verbose 👉 error-prone 👉 easy to forget cases 🚀 Modern Java return switch (obj) { case User user -> user.getName(); case Admin admin -> admin.getRole(); default -> throw new IllegalStateException(); }; ⚡ Even better with sealed classes Java sealed interface Account permits User, Admin {} 👉 Now the compiler knows all possible types 👉 and forces you to handle them 💥 Why this matters less boilerplate safer code (exhaustive checks) fewer runtime bugs 👉 the compiler does more work for you ⚠️ What I still see in real projects old instanceof patterns manual casting everywhere missing edge cases 🧠 Takeaway Modern Java is not just about performance. It’s about writing safer and cleaner code. 🔍 Bonus Once your code is clean, the next challenge is making it efficient. That’s what I focus on with: 👉 https://joptimize.io Are you still writing Java 8-style code in 2025? #JavaDev #Java25 #Java21 #CleanCode #Backend #SoftwareEngineering
To view or add a comment, sign in
-
🚀Stream API in Java - Basics Every Developer Should Know When I started using Stream API, I realized how much cleaner and more readable Java code can become. 👉Stream API is used to process collections of data in a functional and declarative way. 💡What is a Stream? A stream is a sequence of elements that support operations like: ->filtering ->mapping ->sorting ->reducing 💠Basic Example List<String> list = Arrays.asList("Java", "Python", "Javascript", "C++"); list.stream().filter(lang-> lang.startsWith("J")) .forEach(System.out : : println); 👉 outputs :Java, Javascript 💠Common Stream Operations ☑️filter() -> selects elements ☑️map() -> transforms data ☑️sorted() -> sorts elements ☑️forEach() -> iterates over elements ☑️collect() -> converts stream back to collection 💠Basic Stream Pipeline A typical stream works in 3 steps: 1. Source -> collection 2. Intermediate Operations -> filter, map 3. Terminal operation -> forEach, collect ⚡Why Stream API? . Reduces boilerplate code . Improves readability . Encourages functional programming . Makes data processing easier ⚠️Important Points to remember . Streams don't store data, they process it . Streams are consumed once . Operations are lazy (executed only when needed) And Lastly streams API may seem confusing at first, but with practice it becomes a go-to tool for working with collections. #Java #StreamAPI #JavaDeveloper #Programming #SoftwareEngineering #BackendDevelopment #LearningInPublic
To view or add a comment, sign in
-
-
Built DTOForge, a small Spring Boot tool that generates Java DTOs from JSON. Useful when integrating external APIs and you do not want to keep writing DTOs by hand. Supports: * Java records * Java classes * nested objects * arrays * optional Jackson annotations Source: `https://lnkd.in/eWEpUxPY Medium article: https://lnkd.in/eDmK-eVx #Java #SpringBoot #OpenSource #BackendDevelopment #APIIntegration
To view or add a comment, sign in
-
Top 5 Causes of Memory Leaks in Java 🚀 Memory leaks in Java may not cause immediate crashes, but they can significantly degrade performance over time. These leaks occur when objects are no longer needed but are still referenced, preventing Garbage Collection from cleaning them up. The top causes of memory leaks in Java include: 1. Unused objects still referenced – Objects remain in memory due to active references. 2. Static collections – Data continues to grow because static variables persist for the entire application lifecycle. 3. Incorrect equals() and hashCode() – This can lead to duplicate entries in collections like HashMap. 4. Unclosed resources – Resources such as database connections, streams, or sessions are not properly closed. 5. Non-static inner classes – These classes hold implicit references to outer class objects. Understanding these causes can help developers write more efficient Java applications.
To view or add a comment, sign in
-
-
Starting from JDK25, you can write a simple Java entry point (JVM main method) program as, ``` void main() { IO.println("Hello, World!"); } ``` and more interactively, ``` void main() { String name = IO.readln("Please enter your name: "); IO.print("Pleased to meet you, "); IO.println(name); } ``` 1. Both the above variants are single-file source-code programs (compact source file) 2. Automatically imports commonly used base packages such as java.io, java.math, and java.util via automatic import of the java.base module 3. To evolve a compact source file into a ordinary source file, all you need to do is wrap its fields and methods in an explicit class declaration and add an import declaration Assuming this program is in the file HelloWorld.java, you can run it directly with the source-code launcher: $ java HelloWorld.java Previously, the above simple Java program would look like below, ``` public class HelloWorld { public static void main(String[] args) { System.out.println("Hello, World!"); } } ``` where, 1. "public" access modifier & "class" declaration provides for proper encapsulation boundaries 2. "static" modifier provides for a class-object modelling 3. String[] args parameter provides for the program execution inputs 4. System.out.println provides utilities for printing to the console More details in the JEP512 - https://lnkd.in/g5JBAWwe advocating the simplification
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