Skip to content

Latest commit

 

History

History
179 lines (123 loc) · 21.3 KB

File metadata and controls

179 lines (123 loc) · 21.3 KB

Refactoring 016 - Build With The Essence

Refactoring 016 - Build With The Essence

Building Immutable foundations from the ground

TL;DR: Pass essential attributes during object creation to reduce mutability and eliminate getters and setters.

Problems Addressed

Related Code Smells

Code Smell 28 - Setters

Code Smell 68 - Getters

Code Smell 01 - Anemic Models

Code Smell 131 - Zero Argument Constructor

Steps

  1. Identify essential attributes required for object creation
  2. Create a constructor that accepts all essential attributes
  3. Remove setter and getter methods
  4. Update object creation calls to pass all required attributes upfront

Sample Code

Before

public class CreditCard {
    private String cardNumber;
    private String cardHolderName;
    private String expirationMonthYear;
    private int cvv;

    public CreditCard() {} // Empty Constructor

    public void setCardNumber(String cardNumber) { 
        this.cardNumber = cardNumber; 
    }
    public void setCardHolderName(String cardHolderName) { 
        this.cardHolderName = cardHolderName; 
    }
    public void setExpirationMonthYear(String expirationMonthYear) { 
        this.expirationMonthYear = expirationMonthYear;
    }
    public void setCvv(int cvv) { 
        this.cvv = cvv; 
    }

    public String getCardNumber() { 
        return cardNumber; 
    }
    public String getCardHolderName() {
        return cardHolderName;
    }
    public String getExpirationMonthYear() {
        return expirationMonthYear; 
    }
    public int getCvv() {
        return cvv; 
    }
}

CreditCard card = new CreditCard();
card.setCardNumber("1234-5678-9012-3456");
card.setCardHolderName("Lilywhite Lilith");
card.setExpirationMonthYear("12/25");
card.setCvv(123);

After

public class CreditCard {
    private final String cardNumber;
    private final String cardHolderName;
    private final String expirationMonthYear;
    private final int cvv;

    public CreditCard(String cardNumber,
                      String cardHolderName,
                      String expirationMonthYear,
                      int cvv) {
        // 1. Identify essential attributes for object creation
        // 2. Create a constructor that accepts all essential attributes
        this.cardNumber = cardNumber;
        this.cardHolderName = cardHolderName;
        this.expirationMonthYear = expirationMonthYear;
        this.cvv = cvv;
    }

    // 3. Remove setter and getter methods 
    
    // Find real behavior related to credit card usage
  
}

// 4. Update object creation calls to pass all required attributes upfront
CreditCard card = new CreditCard("1234-5678-9012-3456",
                                 "Lilywhite Lilith", 
                                 "12/25", 
                                 123);

Type

[X] Semi-Automatic

This is a step-by-step refactor.

Safety

This refactoring is generally safe if you ensure you pass all essential attributes during object creation.

You must update all object creation sites, which may require refactoring tools and careful review in larger codebases.

Why is the Code Better?

The refactored code enforces object integrity by requiring all essential attributes at creation time.

The objects become thread-safe reducing the risk of being in an inconsistent state.

AI Correction

Most AI tools can correct this code with explicit instructions.

You can have clear pre-prompts requesting all your code samples to favor immutability.

Try Them!

Remember AI Assistants make lots of mistakes

Without Proper Instructions With Specific Instructions
ChatGPT ChatGPT
Claude Claude
Perplexity Perplexity
Copilot Copilot
Gemini Gemini

Tags

  • Mutability

Related Refactorings

Refactoring 001 - Remove Setters

See also

Nude Models - Part I: Setters

Nude Models - Part II: Getters

The Evil Power of Mutants

Credits

Image by Denis on Pixabay


This article is part of the Refactoring Series.

How to Improve Your Code With Easy Refactorings