java声明byte类型数据_java-关于byte类型数据的一些问题

byte类型数据的范围

Java中一个byte类型数据的大小是一个字节,即8位,其范围是-128(1000_0000) ~ 127(0111_1111),二进制的最高位是符号位。

使用二进制形式赋值报错问题

为byte类型变量赋值只能是-128~127范围内的数。

可以使用二进制形式赋值,如:byte b = 0b10011; (b=19)。且使用二进制赋值时,系统是以补码形式解析赋值的二进制数(如对于0b10011是19;对于0b1111_1101则是-3)。

若想使用二进制形式赋值一个负数,如:byte b = 0b1001_0101;,编译器会报类型不兼容的错误(int不能赋值给byte)。需要添加类型强制转换:byte b = (byte) 0b1001_0101;

byte共有8个比特位,其中最高位是符号位,给它赋值0b1001_0101时,最高位的1系统无法判断是实际数值还是符号位数值。添加强制类型转换(byte),则系统可以知道1是符号位,此时可以被赋值;如果没有加强制类型转换,则系统认为0b1001_0101是一个int类型数据。int类型值无法赋值给byte变量,所以会报错。

以二进制形式输出byte

以二进制形式输出byte可以通过包装类Integer的静态方法toBinaryString(int i)。

示例:

byte a = 2;

byte b = 12;

System.out.println(Integer.toBinaryString(a));

System.out.println(Integer.toBinaryString(b));

/**

输出:

10

1100

*/

但若是通过该方法输出一个负数的byte变量,会看到结果是输出了一个32位的二进制数,如:

byte a = -2;

System.out.println(Integer.toBinaryString(a));

/**

输出:

11111111111111111111111111111110

*/

这是因为byte值被赋值给toBinaryString()方法时被转换为int类型,即变成32位。对于上个例子的正数也一样被转换为int,只不过因为是正数,所以高位的0可以被省略,因而看起来是正常显示;但对于负数,高位的1不可以省略,所以以32位形式显示。

针对负数的byte,可以截取结果的后8位,如下:

public static void main(String[] args) throws IOException {

byte a = -2;

String aBinary = Integer.toBinaryString(a);

aBinary = aBinary.substring(aBinary.length()-8);

System.out.println("原二进制数:" + Integer.toBinaryString(a));

System.out.println("截取后的二进制数:" + aBinary);

}

/**

输出:

原二进制数:11111111111111111111111111111110

截取后的二进制数:11111110

*/

一个Integer.toBinaryString()处理byte值(对于正数,进行左补0;对于负数,截取后8位)的示例:

public class Test {

public static void main(String[] args) throws IOException {

byte a = 2;

byte b = -2;

String aBinary = getBinaryByteStr(Integer.toBinaryString(a));

String bBinary = getBinaryByteStr(Integer.toBinaryString(b));

System.out.println(aBinary);

System.out.println(bBinary);

}

private static String getBinaryIntWithZero(String binary){

int zeroCount = 8 - binary.length();

String zeros = "";

if(zeroCount > 0){

for (int i = 0; i < zeroCount; i++) {

zeros += 0;

}

}

return zeros + binary;

}

/**

* 获取8位二进制形式

*/

public static String getBinaryByteStr(String b){

if(b.length()>8){

return b.substring(b.length()-8);

}

else {

return getBinaryIntWithZero(b);

}

}

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值