场景:有一个函数的返回值是一个状态量,我希望用这个状态量的每一位来表示一种状态的T/F。迫于强迫症,这个返回的值应该是负数的。
所以一开始我大概是这样写的
if(xxx)
{
res |= -1;
}
if(yyy)
{
res |= -2;
}
if(zzz)
{
res |= -4;
}
但是这个结果一直是-1。原来以为负数的或运算和正数的或运算是一样的,-1 | -2 = -3这样的。后来想了下,因为在计算机里存的是补码,-1的补码是:1111 1111,那再怎么做或运算,它的结果也是-1。
其实要修改这个也很简单,res在前面或正数(初始值为0),res在最后再乘-1。只是在这个过程中又认识到自己的zz了。
顺便为什么1000 0000 是-128的补码,按取反+1的逻辑来算:(128其实已经越界了,最大表示值是+127)1000 0000 -> 0111 1111 + 1 -> 1000 0000。其实一共256个数,正数127个,零1个,那负数只能是128个,所以一定有-128,那-127是1000 0001,-128就是1000 0000喽!