//原码,反码,补码 与移位操作符
int main() {
int a = -1;
//整形的二进制表现有:原码,反码,补码
// 存储到内存的是补码
//例如 -1
// 32位bit 的第一位是符号位:正数符号位是0,负数符号位是1
// 10000000 00000000 00000000 00000001 原码
// 11111111 11111111 11111111 11111110 反码 (原码->反码,符号位不变,其他位按位取反)
// 11111111 11111111 11111111 11111111 补码 (反码+1)
int b = a << 1; //向左移一位,右边补 0 , 11111111 11111111 11111111 11111110 = -2
int d = a >> 1; //向右移一位,左边补符号位 , 11111111 11111111 11111111 11111111 = -1
printf("%d",b);
return 0;
}