When I receive code I have not seen before to refactor it into some sane state, I normally fix “cosmetic” things (like converting StringTokenizers to String#split(), replacing pre-1.2 collections by newer collections, making fields final, converting C-style arrays to Java-style arrays, …) while reading the source code I have to get familiar with.
Are there many people using this strategy (maybe it is some kind of “best practice” I don’t know?) or is this considered too dangerous, and not touching old code if it is not absolutely necessary is generally prefered? Or is it more common to combine the “cosmetic cleanup” step with the more invasive “general refactoring” step?
What are the common “low-hanging fruits” when doing “cosmetic clean-up” (vs. refactoring with more invasive changes)?
In my opinion, “cosmetic cleanup” is “general refactoring.” You’re just changing the code to make it more understandable without changing its behavior.
I always refactor by attacking the minor changes first. The more readable you can make the code quickly, the easier it will be to do the structural changes later – especially since it helps you look for repeated code, etc.
I typically start by looking at code that is used frequently and will need to be changed often, first. (This has the biggest impact in the least time…) Variable naming is probably the easiest and safest “low hanging fruit” to attack first, followed by framework updates (collection changes, updated methods, etc). Once those are done, breaking up large methods is usually my next step, followed by other typical refactorings.