都说printHexByByteArray方法里面buf[i]要加一个&0xff,否则会输出0ffffffa之类的字符,那么为什么第一个方法printHex里面的b不需要就能输出正确呢

来源:4-2 字节流之文件输入流FileInputStream-2

Juneava

2016-10-30 14:47

如题如题如题

写回答 关注

6回答

  • 小凡先森
    2017-04-06 11:06:15
    已采纳

    简单点说,原来开辟空间之后输入的buf是Byte型,只有8位。现在要用Integer.toHexString把int型转化成字符型,这个函数括号里输入的一定要是int型也就是32位;为了不发生错误,就先用位与&把Byte型(只有8位)前面的24位全都变成0(比如:byte数据1011 1011&1111 1111 1111 1111....,按位运算,高位不足补0,1&1=1,1&0=0,0&0=0)。打个比方就是:8个乒乓球(byte数据)放到长度为32的筒状盒子(Integer)里,为了让这8个球不乱晃并且刚好贴近开口方便拿(可以正确读取),就把底部24个长度用废报纸(与0xff得到的高24位)塞上。有或者没有&0xff看具体用什么数据类型,不是都要加的,“与ff”是数据存储时把短数据变成长数据的常用做法。

    Juneav...

    非常感谢!

    2017-04-06 18:41:42

    共 1 条回复 >

  • 落叶萧萧online
    2017-04-16 16:44:46

    源码里已经进行了&0xff操作

  • 战胜不可能FUE
    2017-02-12 16:34:17

    你肯定之前的没看懂,老实说read读取低8位,其余为补0,用Integer.toHexString()方法就不会输出前面的0;相反去过在不知道其位的情况下,需要&0xff手动将其余位清零。具体的你需要知道在计算机中任何数字都以反码存放,去了解相关知识吧。

  • leowei
    2016-11-01 23:05:03

    方法printHex是无符号读取,所有的字节前面都是加24个零,这样就不会出现

    出0ffffffa之类的了


  • 慕标2218814
    2016-10-30 16:50:26

    貌似那里放的是byte还是什么类型。一个byte就是8位(8bit),一个8位的长度所以就能放完。但是int类型占用的是4个字节,每个字节是8位,一共32位,所以要放4次,每次放8位。

  • 慕标2218814
    2016-10-30 16:07:38

    因为第一个里面的放置的都是用8位就能表示完的数或者什么的,没必要这样做了。建议去看看微机原理,进制和数据表示。

    Juneav...

    怎么看出来第一个里面的放置的都是用8位就能表示完的数?

    2016-10-30 16:33:42

    共 1 条回复 >

文件传输基础——Java IO流

为您介绍IO流的使用,以及对象的序列化和反序列化的内容

133769 学习 · 1030 问题

查看课程

相似问题