Using DI to Avoid Inheritance

I often find myself using inheritance to try and DRY up my codebase. However, that can easily lead to inheritance hell, which you know you are in when:

  • You have to implement methods you don't want/need in child classes.
  • You enter the "great" territory with great-grandparent and great-great-grandparent classes.
  • The complexity of overrides mean that you can't hold the flow in your mind.
  • You start getting obscure/complicated bugs that slip through because of the previous point.

To demonstrate how one might be able to avoid inheritance, I have created the screen-shot below that shows two implementations of the same behavior. It has a DRY codebase where the main logic of foo has only been written once. The implementation on the right uses inheritance whilst the one on the left uses DI. In certain scenarios, you may be able to use this to avoid making children.

To see the key difference here, imagine you want to create a third resource controller that implements a different version of foo() that doesn't use a table handler. This class would still need to implement a getTableHandler method even though it is not used.

Author

Programster

Stuart is a software developer with a passion for Linux and open source projects.

comments powered by Disqus
We are a participant in the Amazon Services LLC Associates Program, an affiliate advertising program designed to provide a means for us to earn fees by linking to Amazon.com and affiliated sites. More info.