1、关于负数移位:负数的二进制表示为 正数 取反 +1
右移: 高位补1(即 补上符号位)其他位向右移动1位
eg.
1) char n = -1; // ~0x01 +1 = ~(0000 0001) +1 = (1111 1110) +1 = (1111 1111) = 0xFF;
//=>不管向右移动多少位,值都是 0xFF(-1)
2) char n = 127(0x0111 1111 = 0x7F);
//右移1位,0x7F >> 1 = 0x3F
//右移2位,0x7F >> 2 = 0x1F
3) char n = -127(0x1000 0001 = 0x81);
//右移1位,0x81 >> 1 = 1100 0000(二进制) = 0xC0
//右移2位,0x7F >> 2 = 1110 0000(二进制) = 0xE0
//右移3位,0x7F >> 3 = 1111 0000(二进制) = 0xF0
左移: 高位补1(即 补上符号位)其他位向右移动1位
eg.
1) char n = 0x81; // = (1000 0001) = -127;
//左移1位,0x81 << 1 = (0000 0010) = 0x02
//左移2位,0x81 << 2 = (0000 0100) = 0x04
//左移3位,0x81 << 3 = (0000 1000) = 0x08
2) char n = 127(0x0111 1111 = 0x7F);
//左移1位,0x7F << 1 = 0x7E
//左移2位,0x7F << 2 = 0x7C