I’m revisiting data structures and algorithms to refresh my knowledge and from time to time I stumble across this problem:
Often, several data structures do need to swap some elements on the underlying array. So I implement the swap() method in ADT1, ADT2 as a private non-static method. The good thing is, being a private method I don’t need to check on the parameters, the bad thing is redundancy. But if I put the swap() method in a helper class as a public static method, I need to check the indices every time for validity, making the swap call very unefficient when many swaps are done.
So what should I do? Neglect the performance degragation, or write small but redundant code?
Better design should always trump small inefficiencies. Only address performance problem if it actually is proven to be one.
Besides, what kind of checking are you doing anyway? Aren’t naturally thrown
ArrayIndexOutOfBoundsExceptionand/orNullPointerExceptiongood enough?It’s worth nothing that while there’s
public static Collections.swap(List<?>,int,int),java.util.Arraysmakes its overloads (forint[], long[], byte[], etc) allprivate static.I’m not sure if Josh Bloch ever explicitly addressed why he did that, but one might guess that it has something to do with Item 25 on his book Effective Java 2nd Edition: Prefer lists to arrays. Yes, there will be “performance degradation” in using
List, but it’s negligible, and the many advantages more than make up for it.