Java 位运算再学习

代码Review中出现的问题. 基础知识不是很牢固,要时刻注意积累.


基础知识

byte:一个字节(8位)(-128~127)(-2的7次方到2的7次方-1)

short:两个字节(16位)(-32768~32767)(-2的15次方到2的15次方-1)
int:四个字节(32位)(一个字长)(-2147483648~2147483647)(-2的31次方到2的31次方-1)
long:八个字节(64位)(-9223372036854774808~9223372036854774807)(-2的63次方到2的63次方-1)
float:四个字节(32位)(3.402823e+38 ~ 1.401298e-45)(e+38是乘以10的38次方,e-45是乘以10的负45次方)
double:八个字节(64位)(1.797693e+308~ 4.9000000e-324


java 中 int是32位 Bit(位)  byte 是8位 Bit(位)

如果底层(如c++, 协议中的数据一般都是 unsigned的正数byte )传来一个值是无符号的byte b = 0x8a(1000 1010) (138)

传给java 就会变成 -118  这时候处理要特别小心,

如果想取出他的正数值,可以将他转成int,  这时候是不应该用 int进行强转的, 而应该用 b &0xFF  = 128

此时 b 没有损失的变成了一个int值.

1000 1010 &(前面还有24个0) 0000 fffff = 0000 1010 = 138

 b & 0x80 取出最高位,其他都是0

 b& 0x7f把最高位置为0











你可能感兴趣的:(Java 位运算再学习)