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/c6c23/c6c2303df84c6982a6e4d35a9e7f94857becac79" 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/0d815/0d815c25afa0fadb14b419f43b224b17530af4ba" 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/a3bc9/a3bc9db1f0fcbe28af54edf01566fd26aaeed25b" 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).