Refused Bequest
Signs and Symptoms
If a subclass uses only some of the methods and properties inherited from its parents, the hierarchy is off-kilter. The unneeded methods may simply go unused or be redefined and give off exceptions.
data:image/s3,"s3://crabby-images/8a25e/8a25ebf6514b3b9a30605b8f8dacd40762a649c5" alt=""
Reasons for the Problem
Someone was motivated to create inheritance between classes only by the desire to reuse the code in a superclass. But the superclass and subclass are completely different.
Treatment
- If inheritance makes no sense and the subclass really does have nothing in common with the superclass, eliminate inheritance in favor of Replace Inheritance with Delegation.
data:image/s3,"s3://crabby-images/1c3a3/1c3a311552fd06639278f6aa4e41c68042a85f78" alt=""
- If inheritance is appropriate, get rid of unneeded fields and methods in the subclass. Extract all fields and methods needed by the subclass from the parent class, put them in a new subclass, and set both classes to inherit from it (Extract Superclass).
Payoff
- Improves code clarity and organization. You will no longer have to wonder why the
Dog
class is inherited from theChair
class (even though they both have 4 legs).
data:image/s3,"s3://crabby-images/1c691/1c69177d6763ad9ad2c43a6fef3635edb7965a0e" alt=""