内存中16进制转化为10进制的问题
假如内存中有如一段内存:
ff ff 32 56 20 05 06 07 08 09 0a 0b 0c ,需要把32 56读出为unsigned short int,求这个int值
typedef union _Hex
{
unsigned short uNum;
struct _half
{
unsigned char height;
unsigned char low;
}half;
}HexToInt;
char buffer[25] = {0};
int iIndex = 0;
buffer[iIndex++] = 0xff;
buffer[iIndex++] = 0xff;
buffer[iIndex++] = 0x32;
buffer[iIndex++] = 0x56;
buffer[iIndex++] = 0x20;
for (int i = 5;i < 25;++i)
{
buffer[i] = i;
}
unsigned short *pInt = (unsigned short *)buffer32;
int iNum = pInt[0];
way2:
sprintf(buffer,"%x%x",unsignedCha32,unsignedCha00);//buffer is "3256"
int iValue = 0;sscanf(buffetr,"%x",&iValue);//iValue = 50;
//way3: use byte operation
int M = buffer[2];
int iLow = M & 0x0F;
int iHei = (M>>4)&0x0F;
//way4: use the union
HexToInt hex;
hex.half.height = (unsigned char)buffer[2];
hex.half.low = (unsigned char)buffer[3];
unsigned short uShort = hex.uNum;
作为一个计算机相关专业的飞鸽传书,我们应该在计算机组成中都学习过什么叫Little endian和Big endian。Little endian和Big endian是CPU存放数据的两种不同顺序。对于整型、长整型等数据类型,Big endian认为第一个字节是最高位字节(按照从低地址到高地址的顺序存放数据的高位字节到低位字节);而Little endian则相反,它认为第一个字节是最低位字节(按照从低地址到高地址的顺序存放数据的低位字节到高位字节)。
参考文章:点击打开链接