美文网首页
byte&0XFF的基础

byte&0XFF的基础

作者: 静默加载 | 来源:发表于2019-06-04 09:51 被阅读0次

前言

最近在做代码相关的优化,找到了一个二进制转十六进制的方法:

/**
 * 二进制转16进制
 * @param bin
 * @return 16进制字符串
 */
public static String asHex(byte[] bin) {
    //一个byte为8位,一个十六进制为4位,所以长度乘以2
    StringBuilder bfHex = new StringBuilder(bin.length * 2);
    int i;
    for (i = 0; i < bin.length; i++) {
        if (((int) bin[i] & 0xff) < 0x10)
            //如果小于10,那么转化为16进制需要往前面加0,凑足两位
            bfHex.append("0");
        //转为为16进制字符串
        bfHex.append(Integer.toString((int) bin[i] & 0xff, 16));
    }
    return bfHex.toString();
}

为什么byte转int需要与0XFF

0XFF = {[0,0,0,0,0,0,0,0],[0,0,0,0,0,0,0,0],[0,0,0,0,0,0,0,0],[1,1,1,1,1,1,1,1]};

  • 一个 int 类型的数字 &0XFF ,就是将这个数字的高24位全部置为0;

byte转化为一个int类型直接强转不行么?

  • 一个byte 转化为32位的 int 类型,它的数值大小不会发生任何变化;
  • 如果是正数那么高位自动补充 0
  • 如果是负数那么高位补充的是 1

我们先看一段代码:

public static void main(String[] args) {
    System.out.println(Integer.toBinaryString(1));
    System.out.println(Integer.toBinaryString(-1));
}

输出结果:

1
11111111111111111111111111111111
  • 学习计算机原理的时候我们知道计算机都是采用补码存储数据的;
1 = byte[00000001] = int {000000000000000000000000000000001} = 0x1
-1 = byte[11111111] = int {11111111111111111111111111111111} = 0xffffffff

我们在做二进制转16进制的时候,需要的是数据的正确性而不是数值的正确性。所以我们进行 0XFF 的时候抹掉了高24位,确保了数据二进制补码的完整新(同时也解释了转化的16进制如果小于10需要在前面加0的原因)。

byte&0xff.png

我们从 BufferedInputStream.java 源代码中都可以找到获取下一个字节的方法 int read() ,最后的得到的字节也是需要 &0xff 转化为 int 类型进行返回的,这样才能保证数据的完整性。

总结

源码、反码、补码

源码

[+1]原 = 0000 0001
[-1]原 = 1000 0001

原码就是符号位加上真值的绝对值, 即用第一位表示符号, 其余位表示值.;

反码

[+1] = [00000001]原 = [00000001]反
[-1] = [10000001]原 = [11111110]反

正数的反码是其本身;
负数的反码是在其原码的基础上, 符号位不变,其余各个位取反;

补码

[+1] = [00000001]原 = [00000001]反 = [00000001]补
[-1] = [10000001]原 = [11111110]反 = [11111111]补

正数的补码就是其本身;
负数的补码是在其原码的基础上, 符号位不变, 其余各位取反, 最后+1. (即在反码的基础上+1);

补码的设计有意识的引用了模运算在数理上对符号位的自动处理,利用模的自动丢弃实现了符号位的自然处理,仅仅通过编码的改变就可以在不更改机器物理架构的基础上完成的预期的要求(将减法变为加法),所以补码沿用至今。

计算机巧妙地把符号位参与运算, 并且将减法变成了加法, 背后蕴含了怎样的数学原理呢?

将钟表想象成是一个1位的12进制数. 如果当前时间是6点, 我希望将时间设置成4点, 需要怎么做呢?我们可以:

  1. 往回拨2个小时: 6 - 2 = 4
  2. 往前拨10个小时: (6 + 10) mod 12 = 4
  3. 往前拨10+12=22个小时: (6+22) mod 12 =4

2,3方法中的mod是指取模操作, 16 mod 12 =4 即用16除以12后的余数是4。 同余定理
所以钟表往回拨(减法)的结果可以用往前拨(加法)替代!

首先要确定二进制中模到底是多少。

在二进制加法运算中膜有0~127,膜为128(128个数),即为2的n次方。
2的n次方减一 = A + A[反]
2的n次方 = A + A[反] + 1
A[补] = A[反] + 1
2的n次方 = A + A[补]

所以可以将负数用补码方式进行变化进行 加操作 ,符号为也可以参与运算。

文章到这里就全部讲述完啦,若有其他需要交流的可以留言哦~!~!

相关文章

  • byte&0XFF的基础

    前言 最近在做代码相关的优化,找到了一个二进制转十六进制的方法: 为什么byte转int需要与0XFF 0XFF ...

  • jQuery基础的基础的基础

    jQuery必会的东西............感觉最近这几天都懵懵的 还是记录一下 防止随着年龄的增长记忆力退化...

  • 基础的基础

    在40多年前中国大陆还没有摩天大楼,随着不断的追逐,一栋栋大楼拔地而起,虽然战果辉煌,然而有多少成为了烂尾楼。 ...

  • 基础中的基础

    作为道门信士,应该明白道门的宗旨有两条是区别于其他宗教的,一是自由,道教崇尚自然,讲究逍遥应世,相对其他宗教而言,...

  • markdown 基础语法,基础中的基础

    一、标题设置 我是1级标题 我是2级标题 我是3级标题 我是4级标题 我是5级标题 我是6级标题 标题共6级 二、...

  • 机械设备安装技术

    设备基础种类及应用 垫层基础允许产生沉降:大型储罐 浅基础扩展基础联合基础:轧机独立基础 深基础桩基础:适用于需要...

  • 基础,基础,基础

    如果有人现在问我,JAVA该怎么学,我会告诉他不要急于求成,少看视频,多练,多思考。但说到这里有人可能会反...

  • 【Android】知识点汇总,坚持原创ing

    Android基础 Java基础 Java基础——Java内存模型和垃圾回收机制 语法基础 语法基础——C语法基础...

  • 0.介绍

    选项基础:介绍 选项基础:什么是期权? 选项基础:为什么使用期权? 选项基础:期权如何工作 选项基础:期权的类型 ...

  • 彭壮:千川基础实操计划详解18条(极速推广)

    01 计划组合的分类: 基础定向+行为兴趣 基础定向+抖音达人 基础定向+达人分类 基础定向+人群包 基础定向+行...

网友评论

      本文标题:byte&0XFF的基础

      本文链接:https://www.haomeiwen.com/subject/htpvtctx.html