• Ephera@lemmy.ml
    link
    fedilink
    arrow-up
    10
    arrow-down
    16
    ·
    4 months ago

    Alright, spicy opinion time: I think, the ! operator is dumb.

    It’s yet another symbol with a meaning, which people have to learn.

    And it’s easy to overlook, especially in languages with parentheses in their if-conditions:

    if (!list.isEmpty()) { ... }
    

    I think that just a .not() method on Booleans is cooler:

    if (list.isEmpty().not()) { ... }
    

    You can do this in Rust, which is where I have that idea from: https://play.rust-lang.org/?version=stable&mode=debug&edition=2021&gist=dedb71bd84243c78ee0afad0f30b80c3

    • DarkenLM@kbin.earth
      link
      fedilink
      arrow-up
      29
      ·
      4 months ago

      Mathematics themselves are essentially tons of symbols that people have to learn, tbf.

      I personally never had any trouble looking at the negation operator, and find the .not() postfix cumbersome.

    • yetAnotherUser@discuss.tchncs.de
      link
      fedilink
      arrow-up
      20
      ·
      edit-2
      4 months ago

      I dislike the .not() method a bit because it inverts the meaning of the previous code snippet you’ve read.

      if (list.isEmpty()...
      

      “Ah, so if the list is empty…”

      if (list.isEmpty().not())
      

      “Goddammit”

      • Ephera@lemmy.ml
        link
        fedilink
        arrow-up
        7
        ·
        4 months ago

        For me, it’s pretty much the opposite. With the exclamation mark, I’ll see the inversion, then I’ll read the actual condition and try to make sense of it, and then I’ll remember that this thing was supposed to be inverted. Or I won’t remember, that’s unfortunately also a possibility.

        Might just be what we’re used to, though. I have been working in a codebase with mostly .not() for the past year.

      • Zagorath@aussie.zone
        link
        fedilink
        arrow-up
        5
        ·
        4 months ago

        We could have used the tilde, which has been used in formal logic & maths for negation in very many contexts for a long time.

        It’s used instead in C and many C-like languages for the far less useful bitwise negation. Of course, we could have had it work in the same way as bitwise vs logical and & or, by dialling up the symbol. Which would have massively improved its visibility compared to the bang.

        But for some reason, no. They chose the bang instead.

      • Deebster@programming.dev
        link
        fedilink
        arrow-up
        4
        ·
        4 months ago

        My (ISO) keyboards do, under the Esc key. I guess you’re in North America (or Australia) and have an ANSI layout.

      • Ephera@lemmy.ml
        link
        fedilink
        arrow-up
        1
        arrow-down
        1
        ·
        4 months ago

        Oh, I know where it came from. That’s also why we have all kinds of maths operators in the syntax of virtually any programming language. Because back when we didn’t yet know where this programming thing was going, we just threw in the conventions of maths and theoretical logic.

        What I’m saying is that we have our own conventions now, i.e. objects and methods, so I think, it’s worth reconsidering whether we still want to have these old conventions that are special cases in the syntax.

    • rockSlayer@lemmy.world
      link
      fedilink
      arrow-up
      13
      ·
      4 months ago

      It’s ok for symbols to have different meanings in different contexts. If someone is new to the context, they should research or ask about it. People that are familiar should provide the mutual understanding, provided they have the will and ability to educate.

    • petersr@lemmy.world
      link
      fedilink
      arrow-up
      5
      ·
      4 months ago

      Would you say that it reads better as “not x” or “x not” (if we remove all special characters)?

      • Ephera@lemmy.ml
        link
        fedilink
        arrow-up
        2
        ·
        4 months ago

        I mean, that is more obvious and more readable.

        But what I really don’t like about it, is that it’s less clear to what it applies. For example:

        not list.isEmpty() and x > 3
        

        Is that not (a and b) or (not a) and b?
        Obviously, you can define precedence rules, like there also is for !, but that’s again just additional things to learn.
        I’m definitely not generally opposed to special characters. I do also hate significant whitespace, because I find that less readable than braces.