Remove Setting Method
Problem
The value of a field should be set only when it is created, and not change at any time after that.
Solution
So remove methods that set the field’s value.
Before
data:image/s3,"s3://crabby-images/efc12/efc12fdf8d9fd647fa2037f8328a717a79d95ca7" alt="Remove Setting Method - Before"
After
data:image/s3,"s3://crabby-images/fafe6/fafe66c031617f6c116e19aee1761acc68195702" alt="Remove Setting Method - After"
Why Refactor
You want to prevent any changes to the value of a field.
How to Refactor
-
The value of a field should be changeable only in the constructor. If the constructor does not contain a parameter for setting the value, add one.
-
Find all setter calls.
- If a setter call is located right after a call for the constructor of the current class, move its argument to the constructor call and remove the setter.
- Replace setter calls in the constructor with direct access to the field.
- Delete the setter.