java byte 作比较

本文揭示了Java中byte类型比较时的误区,尤其是涉及到负数和0xFF的情况。通过实例解释了为什么使用(data[0] & 0xFF) == 0xFF能得到正确结果,以及为何直接等于0xFF或-1会有误判。关键在于理解16进制负数在Java中的表示和转换规则。
摘要由CSDN通过智能技术生成

byte作比较需要&0xff

例:

boolean match = ((data[0] & 0xFF) == 0xFF);

为true

boolean match = (data[0] == 0xFF);

为false

boolean match = (data[0] == -1);

为true

所以统一一下,byte作比较,都&0xff

原因:

16进制数0x80,其10进制数是128,二进制数是10000000,在java里,二进制数,以1开头的二进制数转化出来即为负数, 所以直接判断boolean match = (data[0] == 16进制数),需要要求10进制数不能超过128,即最大127(对应的16进制为0x7f,二进制01111111),即boolean match = (data[0] == 0x7F)为true。若超过这个数,则判断就会不准确

 因此统一一下,boolean match = ((data[0] & 0xFF) == 0xFF);
 

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值