将一个字节转换成十六进制数是基于什么样的需要?比如socket报文,别人发的十六进制报文,我在服务端一样可以接收。伪java代码
Socket socket = getSocket();
InputStream in = socket.getInputStream
byte[] bytes = new byte[1024]
in.read(bytes)
...
可能还有一些其它应用用到字节的,有时候为什么一定要转成十六进制数呢?而且我发现用C或者C++的人特别喜欢用十六进制数,难道就是因为可以少写几个数字?
3 回答
繁星点点滴滴
TA贡献1803条经验 获得超3个赞
我想是为了方便吧,如果用2进制的话,一个byte要写8bit,而且在编码时候容易出错。如果用16进制的话,只需要两个写两个字符了。
比如你要给一个变量赋值,是这样好
int a = 0b11000011001111001100011100101000
还是这样好?
int a = 0xC33CC728
至少在我看来第二种好些,直接用二进制看起来不方便,写着也不方便吧。
烙印99
TA贡献1829条经验 获得超13个赞
这是一个错误的答案。
我的理解,将一个byte转为十六进制,可能有很多使用场景,其中一个场景是网络通信。比如进行socket通信时,发送一个byte[]的数据给服务器,服务器接到之后会将请求内容中的每个byte转为十六进制数。每个请求都有对应协议,比如请求中的第x个字节到第y个字节包含什么信息,每个字节中的高位和地位各代表什么信息。然后可以使用位操作运算来存或者取取某个位的值。从而达到通信的目的。
之前实现过一个小的网络通信程序,具体细节已经记不清楚,大体是这样。
这只是一个场景(可以bing一下【网络通信 字节数组】关键字),另外的使用场景还没有接触到。
胡子哥哥
TA贡献1825条经验 获得超6个赞
因为十六进制和二进制之间可以直接对应,一个十六进制位对应四个二进制数。不像十进制那样需要转换。而且能节省很多宽度,毕竟人类不是计算机,二进制天生不是适合人类处理的,除非需要观察具体的二进制位或者位操作,才会去看二进制数。
添加回答
举报
0/150
提交
取消