Boolean true - positive 1 or negative 1?

前端 未结 11 1284
一生所求
一生所求 2020-12-31 11:05

I\'m designing a language, and trying to decide whether true should be 0x01 or 0xFF. Obviously, all non-zero values will be converted to true, but I\'m trying t

相关标签:
11条回答
  • 2020-12-31 11:14

    Whatever you do, once you select your values don't change them. In FORTH-77, true and false were defined as 1 and 0. Then, FORTH-83 redefined them as -1 and 0. There were a not few (well ok, only a few, this is FORTH we are talking about) problems caused by this.

    0 讨论(0)
  • 2020-12-31 11:17

    IMO, if you want to stick with false=0x00, you should use 0x01. 0xFF is usually:

    • a sign that some operation overflowed

    or

    • an error marker

    And in both cases, it probably means false. Hence the *nix return value convention from executables, that true=0x00, and any non-zero value is false.

    0 讨论(0)
  • 2020-12-31 11:19

    Design the language so that 0 is false and non-zero is true. There is no need to "convert" anything, and thinking "non-zero" instead of some specific value will help you write the code properly.

    If you have built-in symbols like "True" then go ahead and pick a value, but always think "non-zero is true" instead of "0x01 is true".

    0 讨论(0)
  • 2020-12-31 11:22

    I think the C method is the way to go. 0 means false, anything else means true. If you go with another mapping for true, then you are left with the problem of having indeterminate values - that are neither true nor false.

    If this is language that you'll be compiling for a specific instruction set that has special support for a particular representation, then I'd let that guide you. But absent any additional information, for an 'standard' internal representation, I'd go with -1 (all 1's in binary). This value extends well to whatever size boolean you want (single bit, 8-bit, 16, etc), and if you break up a "TRUE" or a "FALSE" into a smaller "TRUE" or "FALSE", its still the same. (where if you broke a 16 bit TRUE=0x0001 you'd get a FALSE=0x00 and a TRUE=0x01).

    0 讨论(0)
  • 2020-12-31 11:23

    0 is false because the processor has a flag that is set when a register is set to zero.

    No other flags are set on any other value (0x01, 0xff, etc) - but the zero flag is set to false when there's a non-zero value in the register.

    So the answers here advocating defining 0 as false and anything else as true are correct.

    If you want to "define" a default value for true, then 0x01 is better than most:

    • It represents the same number in every bit length and signedness
    • It only requires testing one bit if you want to know whether it's true, should the zero flag be unavailable, or costly to use
    • No need to worry about sign extension during conversion to other types
    • Logical and arithmetic expressions act the same on it

    -Adam

    0 讨论(0)
  • 2020-12-31 11:24

    -1 is longer to type than 1...

    In the end it doesn't matter since 0 is false and anything else is true, and you will never compare to the exact representation of true.

    Edit, for those down voting, please explain why. This answer is essentially the same as the one currently rated at +19. So that is 21 votes difference for what is the same basic answer.

    If it is because of the -1 comment, it is true, the person who actually defines "true" (eg: the compiler writer) is going to have to use -1 instead of 1, assuming they chose to use an exact representation. -1 is going to take longer to type than 1, and the end result will be the same. The statement is silly, it was meant to be silly, because there is no real difference between the two (1 or -1).

    If you are going to mark something down at least provide a rationale for it.

    0 讨论(0)
提交回复
热议问题