标签:Java 8bits int 串口 127 128 byte 调试器
前置知识点
byte的范围[-128~127] 内存里表现为 0x00~0xFF
刚好是一个8bits的字节
问题
byte[] hexData = new byte[] {0x01, 0x03, 0x04, 0x02, 0x1F, 0x01, 0x4E, 0x4B, (byte)0xE9 };
Java先把括号里的识别为int数,然后再自动转换为byte
这里的int数0xE9,超出了byte的范围[-128~127],所以不会自动转换,必须代码指定强制转换。
那么问题来了,内存里是这样的
调试器结果:
而且打印出来的 (hexData[8])
也是这样,所以不是调试器的问题,而是Java就是这么识别的。
解决
用 (hexData[8]&0xFF)
即可取出低位
揭秘
byte是有符号的,为了方便硬件运算,因此正负转换用了补码
Java所有数默认都识别为int,0xE9 被识别为 (int)233
超出了byte范围[-128~127]。
强制转换为byte后发生上溢,溢出了233-127=106,因此结果为 1+(-128)+106=-21
-21的十六进制为 FFFFFFFFFFFFFFE9
,也就是调试器里的那个数值
所以正数的时候没错,但负数的时候就需要处理了
对于 byte[-128,127], 其[0,127]范围的数据和 int 中的 [0,127] 完全一致,不需要 & 0XFF, 只有对于 [-128,-1] 的 byte 数据才需要 & 0XFF.
标签:Java,8bits,int,串口,127,128,byte,调试器 来源: https://www.cnblogs.com/yucloud/p/Java_byte.html
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。