左移 <<
将二进制数向左移动指定位数
高位溢出则丢弃,低位补0
a = 2
a << 2
'''
1) 移位前转换为二进制数据: 0000 0010
2) a << 2 向左移动2位变为: 0000 1000
3) 移位后转换为十进制数据 a = 8
'''
左移n位,等于a 乘以2的n次方
左移n位的计算速度大于乘法运算的计算速度
右移 >>
将二进制数据向右移动指定位数
有符号位:
1)若为正数,高位补0
2)若为负数, 高位补1(1)正数
a = 4 a >> 2 1) 移位前转换为二进制数据: 0000 0100 2)a >> 2 向右移动2位变成: 0000 0001 3)转换为十进制: a = 1
(2)负数
a = -4 a >> 2 1)移位前转换为二进制数据: 1000 0100 2)a >> 2 向右移动2位变成:1000 0001 3)转换为十进制:a = -1
无符号位:
右移之后,高位补0a = 5 a >> 2 1)移位前转换为二进制数据: 0000 0101 2)a >> 2 向右移动2位变成:0000 0001 3)转换为十进制:a = 1
右移n位,等于 a除以2的n次方的商向下取整
右移n位的计算速度大于除法运算的计算速度