Don’t you believe in magic strings and numbers being bad? From the perspective of readability and future maintenance, constants are better. We all know this is true, and we all know that it can sometimes go too far.
Douwe Kasemier has a co-worker that has taken that a little too far.
For example, they have a Java method with a signature like this:
Document addDocument(Action act, boolean createNotification);
The Action
type contains information about what action to actually perform, but it will result in a Document
. Sometimes this creates a notification, and sometimes it doesn’t.
Douwe’s co-worker was worried about the readability of addDocument(myAct, true)
and addDocument(myAct, false)
, so they went ahead and added some constants:
private static final boolean NO_NOTIFICATION = false;
private static final boolean CREATE_NOTIFICATION = true;
Okay, now, I don’t love this, but it’s not the worst thing…
public Document doActionWithNotification(Action act) {
addDocument(act, CREATE_NOTIFICATION);
}
public Document doActionWithoutNotification(Action act) {
addDocument(act, NO_NOTIFICATION);
}
Okay, now we’re just getting silly. This is at least diminishing returns of readability, if not actively harmful to making the code clear.
private static final int SIX = 6;
private static final int FIVE = 5;
public String findId(String path) {
String[] folders = path.split("/");
if (folders.length >= SIX && (folders[FIVE].startsWith(PREFIX_SR) || folders[FIVE].startsWith(PREFIX_BR))) {
return folders[FIVE].substring(PREFIX_SR.length());
}
return null;
}
Ah, there we go. The logical conclusion: constants for 5 and 6. And yet they didn’t feel the need to make a constant for "/"
?
At least this in maintainable, so that when the value of FIVE
changes, the method doesn’t need to change.