最近做通讯,自己写报文协议,收发4字节16进制数。将十进制与16进制转化,还区分有无符号,自己写的程序70多行,发现这位大神写的极为简单,测试半天没有错误,标记一下,待后期再深究。
原文:
参考简书:https://www.jianshu.com/p/0d75db2b3c14 作者:InterestingPDD
最近做一个项目 要传udp包 包里包含很多信息 就是把一些信息用byte表示 所以包含很多byte的转换 这里记录一下 在网上没查到 只有int的转换这里的例子是8个字节代表一个long long数据。long long转为byte数组
+ (Byte*)longlongToByte:(long long)value
{
Byte * byte = malloc(8);
byte[0] = ((value >> 56) & 0xFF);
byte[1] = ((value >> 48) & 0xFF);
byte[2] = ((value >> 40) & 0xFF);
byte[3] = ((value >> 32) & 0xFF);
byte[4] = ((value >> 24) & 0xFF);
byte[5] = ((value >> 16) & 0xFF);
byte[6] = ((value >> 8) & 0xFF);
byte[7] = (value & 0xFF);
return byte;
}
byte数组转为long long
+ (longlong)byteToLongLong:(Byte*)byte
{
longlongvalue = 0;
value = (((longlong)byte[0] << 56 & 0xFF00000000000000L) |
((longlong)byte[1] << 48 & 0xFF000000000000L) |
((longlong)byte[2] << 40 & 0xFF0000000000L) |
((longlong)byte[3] << 32 & 0xFF00000000L) |
((longlong)byte[4] << 24 & 0xFF000000L) |
((longlong)byte[5] << 16 & 0xFF0000L) |
((longlong)byte[6] << 8 & 0xFF00L) |
((longlong)byte[7] & 0xFFL));
returnvalue;
}
下面是自己改写的。
//4字节,32位10进制转16进制
void Dec2Hex(long long in_DecValue, byte* out_HexBit)
{
out_HexBit[3] = (in_DecValue >> 24) & 0xFF;
out_HexBit[2] = (in_DecValue >> 16) & 0xFF;
out_HexBit[1] = (in_DecValue >> 8) & 0xFF;
out_HexBit[0] = in_DecValue & 0xFF;
}
//4字节,16进制转32位10进制
void Hex2Dec(BYTE* in_HexBit, long long *out_DecValue)
{
*out_DecValue=(
((long long)in_HexBit[0] << 24 & 0xFF000000L) |
((long long)in_HexBit[1] << 16 & 0xFF0000L) |
((long long)in_HexBit[2] << 8 & 0xFF00L) |
((long long)in_HexBit[3] & 0xFFL));
}
& 0xff的理解:
&0xff可以将高的24位置为0,低8位保持原样。这样做的目的就是为了保证二进制数据的一致性。