猿问

将一个字节转换成十六进制数是基于什么样的需要?

将一个字节转换成十六进制数是基于什么样的需要?
比如socket报文,别人发的十六进制报文,我在服务端一样可以接收。
伪java代码

Socket socket = getSocket();
InputStream in = socket.getInputStream
byte[] bytes = new byte[1024]
in.read(bytes)
...

可能还有一些其它应用用到字节的,有时候为什么一定要转成十六进制数呢?
而且我发现用C或者C++的人特别喜欢用十六进制数,难道就是因为可以少写几个数字?

蓝山帝景
浏览 501回答 3
3回答

繁星点点滴滴

我想是为了方便吧,如果用2进制的话,一个byte要写8bit,而且在编码时候容易出错。如果用16进制的话,只需要两个写两个字符了。 比如你要给一个变量赋值,是这样好 int a = 0b11000011001111001100011100101000 还是这样好? int a = 0xC33CC728 至少在我看来第二种好些,直接用二进制看起来不方便,写着也不方便吧。

烙印99

这是一个错误的答案。 我的理解,将一个byte转为十六进制,可能有很多使用场景,其中一个场景是网络通信。比如进行socket通信时,发送一个byte[]的数据给服务器,服务器接到之后会将请求内容中的每个byte转为十六进制数。每个请求都有对应协议,比如请求中的第x个字节到第y个字节包含什么信息,每个字节中的高位和地位各代表什么信息。然后可以使用位操作运算来存或者取取某个位的值。从而达到通信的目的。 之前实现过一个小的网络通信程序,具体细节已经记不清楚,大体是这样。 这只是一个场景(可以bing一下【网络通信 字节数组】关键字),另外的使用场景还没有接触到。

胡子哥哥

因为十六进制和二进制之间可以直接对应,一个十六进制位对应四个二进制数。不像十进制那样需要转换。而且能节省很多宽度,毕竟人类不是计算机,二进制天生不是适合人类处理的,除非需要观察具体的二进制位或者位操作,才会去看二进制数。
随时随地看视频慕课网APP

相关分类

Java
我要回答