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/71f19/71f19f8809ab4de21fe6d8187f322dca28025ad7" 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.
data:image/s3,"s3://crabby-images/c3549/c3549be21b0097cd0c3ffe95a62334dd8f303151" alt=""
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.
-
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 superclass, and set both classes to inherit from it (Extract Superclass).
data:image/s3,"s3://crabby-images/4c174/4c17453bcd026453fe61dc88b795ebc03556e23e" alt=""
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).