Pull Up Field
Problem
Two classes have the same field.
Solution
Remove the field from subclasses and move it to the superclass.
data:image/s3,"s3://crabby-images/df951/df9515f1e7e7e2fe15590495ea40812b1a38705a" alt="Pull Up Field - Before"
data:image/s3,"s3://crabby-images/b677f/b677f727199cb1d5eadd7cec528320124c59239c" alt="Pull Up Field - After"
Why Refactor
Subclasses grew and developed separately, causing identical (or nearly identical) fields and methods to appear.
Benefits
-
Eliminates duplication of fields in subclasses.
-
Eases subsequent relocation of duplicate methods, if they exist, from subclasses to a superclass.
How to Refactor
-
Make sure that the fields are used for the same needs in subclasses.
-
If the fields have different names, give them the same name and replace all references to the fields in existing code.
-
Create a field with the same name in the superclass. Note that if the fields were private, the superclass field should be protected.
-
Remove the fields from the subclasses.
-
You may want to consider using Self Encapsulate Field for the new field, in order to hide it behind access methods.