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

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

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

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

阅读 4.8k
3 个回答

我想是为了方便吧,如果用2进制的话,一个byte要写8bit,而且在编码时候容易出错。如果用16进制的话,只需要两个写两个字符了。

比如你要给一个变量赋值,是这样好

int a = 0b11000011001111001100011100101000

还是这样好?

int a = 0xC33CC728

至少在我看来第二种好些,直接用二进制看起来不方便,写着也不方便吧。

这是一个错误的答案。

我的理解,将一个byte转为十六进制,可能有很多使用场景,其中一个场景是网络通信。比如进行socket通信时,发送一个byte[]的数据给服务器,服务器接到之后会将请求内容中的每个byte转为十六进制数。每个请求都有对应协议,比如请求中的第x个字节到第y个字节包含什么信息,每个字节中的高位和地位各代表什么信息。然后可以使用位操作运算来存或者取取某个位的值。从而达到通信的目的。

之前实现过一个小的网络通信程序,具体细节已经记不清楚,大体是这样。

这只是一个场景(可以bing一下【网络通信 字节数组】关键字),另外的使用场景还没有接触到。

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

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题