Refactoring and Open / Closed principle
Posted
by
Giorgio
on Programmers
See other posts from Programmers
or by Giorgio
Published on 2012-10-19T11:06:37Z
Indexed on
2012/10/19
11:23 UTC
Read the original article
Hit count: 290
I have recently being reading a web site about clean code development (I do not put a link here because it is not in English).
One of the principles advertised by this site is the Open Closed Principle: each software component should be open for extension and closed for modification. E.g., when we have implemented and tested a class, we should only modify it to fix bugs or to add new functionality (e.g. new methods that do not influence the existing ones). The existing functionality and implementation should not be changed.
I normally apply this principle by defining an interface I
and a corresponding implementation class A
. When class A
has become stable (implemented and tested), I normally do not modify it too much (possibly, not at all), i.e.
- If new requirements arrive (e.g. performance, or a totally new implementation of the interface) that require big changes to the code, I write a new implementation
B
, and keep usingA
as long asB
is not mature. WhenB
is mature, all that is needed is to change howI
is instantiated. - If the new requirements suggest a change to the interface as well, I define a new interface
I'
and a new implementationA'
. SoI
,A
are frozen and remain the implementation for the production system as long asI'
andA'
are not stable enough to replace them.
So, in view of these observation, I was a bit surprised that the web page then suggested the use of complex refactorings, "... because it is not possible to write code directly in its final form."
Isn't there a contradiction / conflict between enforcing the Open / Closed Principle and suggesting the use of complex refactorings as a best practice? Or the idea here is that one can use complex refactorings during the development of a class A
, but when that class has been tested successfully it should be frozen?
© Programmers or respective owner