Is naming Booleans that start with "is" bad practice now? My manager believes that "isAnything" is outdated and poor practice. Is this true?
myManager.isLame ? correct() : incorrect();
Is naming Booleans that start with "is" bad practice now? My manager believes that "isAnything" is outdated and poor practice. Is this true?
myManager.isLame ? correct() : incorrect();
It's used quite often in a lot of languages, but I don't know if it can be said with certainty that it's the preferred method.
I think consistency and everyone on a given team using the same standards/styles is the important thing to bear in mind.
I would not use any hard and fast rules here. Although I find a prefix such as 'Is' useful in identifying a boolean property, there are many cases where 'Is' would not be the best choice.
The MSDN naming guidelines include the following relevant advice.
Do name Boolean properties with an affirmative phrase (CanSeek instead of CantSeek). Optionally, you can also prefix Boolean properties with Is, Can, or Has, but only where it adds value.
It's a matter of style, and I've seen it your way lots of times (and do this myself in many languages).
isLame()
is very common, and I consider it to be not lame. In Java, it's part of the JavaBeans specification, and therefore quite an ensconced practice.
Stylistically, my vote would be for hasValue or isNullOrEmpty. Using clever shortcuts or one-line if statements like that, however, is universally bad. It drastically reduces code readability and in most languages will not lead to any performance gain.
it would be better if you create boolean variable with clear name
boolean lame;
and make method to check its value
isLame(){
return lame;
}
It's generally better approach to invoke method over direct access to variable.
Follow a language's documented convention. If there is no convention:
Omit type info in variable naming altogether.
That includes is
for booleans.
boss.lame ? limp() : sprint()
For languages with strong typing the information is redundant.
For languages without strong typing the information is still redundant because IDEs and all of the various tools available now help with typing without having to convolute the names.
is
is a verb. is_lame()
should be an accessor method that returns a boolean value.