• mfz@kbin.social
    link
    fedilink
    arrow-up
    12
    arrow-down
    1
    ·
    1 year ago

    Isn’t the evaluated value different from the expression? i++ returns the value of i before increasing. i-=-1 would return the value after it has been increased. Wouldn’t it be more correct to make it equal to ++i

    • maiskanzler@feddit.de
      link
      fedilink
      arrow-up
      15
      arrow-down
      3
      ·
      1 year ago

      And that’s why post- and pre-increment is non-existant in Python and Rust. It’s an easy source for bugs for a noncritical abbreviation🤷

      • Knusper@feddit.de
        link
        fedilink
        arrow-up
        6
        arrow-down
        4
        ·
        1 year ago

        They’re especially also a source of bugs, because they encourage manually incrementing indices and manually accessing array positions, which is almost never actually sensible.

    • mfz@kbin.social
      link
      fedilink
      arrow-up
      8
      ·
      edit-2
      1 year ago

      If you’re hell bend on achieving the goodness of i++ equivalent you could wrap it up like this:
      (i-=-1,i-1)

      We’re talking C here of course.

    • Knusper@feddit.de
      link
      fedilink
      arrow-up
      6
      ·
      1 year ago

      In the languages I know, i-=-1 or x=3 are not expressions, but rather statements, so they do not evaluate to a value.

      So, this would be a compiler error:

      a = (x=3)
      
      • mfz@kbin.social
        link
        fedilink
        arrow-up
        6
        ·
        1 year ago

        In C you can group expressions within ( and ) separated with ,. Expressions are evaluated in order and the last expression in the group is the returned value of the group.

    • Jamie@jamie.moe
      link
      fedilink
      arrow-up
      2
      ·
      1 year ago

      I gave it a shot in Compiler Explorer, with the following code:

      #include <stdio.h>
      
      int main() {
        for (int i = 0; i < 10; i -= -1) {
          printf("%d", i);
        }
      }
      

      GCC takes the i-=-1 and optimizes it into ADD DWARD PTR [rbp-4], 1, and changing it around to ++i or i++ makes no difference.

      So, at least in C and C++, it works all the same. Even on unsigned integers.

      • mfz@kbin.social
        link
        fedilink
        arrow-up
        4
        ·
        1 year ago

        It works the same because the value of the last expression in the for loop is not used for anything. It’s the side effect of that statement that counts. Eg, the value of i is checked the next time the for loop is executed by the condition check. Try replacing i in the condition check instead with i++ or ++i and you would see different results.

        Something like: for (int i = 0; ++i < 10;) { ... }