this post was submitted on 15 May 2024
2 points (100.0% liked)

Asklemmy

43516 readers
1984 users here now

A loosely moderated place to ask open-ended questions

Search asklemmy πŸ”

If your post meets the following criteria, it's welcome here!

  1. Open-ended question
  2. Not offensive: at this point, we do not have the bandwidth to moderate overtly political discussions. Assume best intent and be excellent to each other.
  3. Not regarding using or support for Lemmy: context, see the list of support communities and tools for finding communities below
  4. Not ad nauseam inducing: please make sure it is a question that would be new to most members
  5. An actual topic of discussion

Looking for support?

Looking for a community?

~Icon~ ~by~ ~@Double_A@discuss.tchncs.de~

founded 5 years ago
MODERATORS
 

What I mean is: some boolean flags are perfect for the real world phenomenon they are representing e.g. is_light_on makes you understand perfectly that when it is true the light is on and when it is false the light is off.

There are other cases in which if you didn't write the code and you don't read any additional documentation, everything is not clear just by looking at the variable name e.g. is_person_standing, when true it's clear what that means but when false, is the person sitting? Lying? Kneeling?

I'm obviously not talking about cases in which there are more states, boolean would of course not be a good solution in those cases. I'm talking about programs in which there are only two states but it's not obvious, without external knowledge, which ones they are.

top 5 comments
sorted by: hot top controversial new old
[–] nycki@lemmy.world 3 points 4 months ago

if the states aren't obvious, use an enum with two values, and name them both. Thats what enums are for.

[–] AlternateRoute@lemmy.ca 1 points 4 months ago

Other states are irrelevant only the true condition implied matters, it is or isn’t that one state.

is_person_standing, is_standing, bStanding all tell you if someone is standing or NOT standing. Nothing else period. It does not matter if there could be other states as the test is one specific case.

[–] hostops@sh.itjust.works 1 points 4 months ago* (last edited 4 months ago)

One should not use boolean just because variable has only two states.

I believe when you use boolean when enum should be used is called "boolean blindness".

Eg: isFemale instead of enum Sex {MALE;FEMALE} It also gives you an option to simply extend code if requirements change and there are more than two options.

[–] SpaceNoodle@lemmy.world 1 points 4 months ago

In your example, it's implied that any pose other than standing is irrelevant in that context. Why do you need to care if you don't need to care?

[–] thepiguy@lemmy.ml 1 points 4 months ago

It shouldn't matter if the user is leaning or jumping or whatever. If the variable says "is_person_standing" then the only information I get out of it is whether the person is standing or not. It would be much simpler to use enums to represent the state if there are such other options. If you don't have enums in your language, then use constants.