so in my application I’ve got several different customers being “serviced”. Each customer has their own implementations of various classes that are all based on interfaces.
With the latest customer being added, I’ve noticed there will be a lot of duplication of code from another customer but the other customer is in no other way related to them.
I’ve already got a default implementation for several other customers and roll new ones as i need them.
My question is how do i refactor this and still keep the code clean? If i were a dev new to this code base i would want each customer to either use the default or their own implementation of these classes… but that’s a lot of duplication.
Consider using an
abstractbase class withabstractorvirtualmembers. Abstract members are essentially equivalent to interface members (they have no build-in behavior, they only guarantee the method exists) whereasvirtualmembers have a default implementation which can be overridden by derived classes.Your question is really too vague to answer in full, but here’s how you can leverage inheritance.
If you want all classes to use the same implementation of a member then that member can be implemented in the base-class.
If you want each class to have its own implementation of a member then you can either use a base-class with
abstractmembers, or an interface.If you want some classes to use the same implementations and others to use different implementations then implementing the default behavior in the base-class and override it as needed.
My main point is that OOP there is a spectrum of how much or little functionality is in base/abstract/concrete classes. There’s no silver-bullet answer, sometimes your base classes will be skeletons and sometimes they’ll be fully fleshed-out; it all depends on the specific problem at hand.