网上看到一道题挺有意思的
//这一堆数据中存储了角色的血值信息,假设血值的类型为int类型,值为100(10进制)
0x00,0x01,0x02,0x03,0x04,0x05,0x16,0x17,0x07,0x09,
0x00,0x20,0x10,0x03,0x03,0x0C,0x00,0x00,0x44,0x00,
0x00,0x33,0x00,0x47,0x0C,0x0E,0x00,0x0D,0x00,0x11,
0x00,0x00,0x00,0x02,0x64,0x00,0x00,0x00,0xAA,0x00,
0x00,0x00,0x64,0x10,0x00,0x00,0x00,0x00,0x00,0x00,
0x00,0x00,0x02,0x00,0x74,0x0F,0x41,0x00,0x00,0x00,
0x01,0x00,0x00,0x00,0x05,0x00,0x00,0x00,0x0A,0x00,
0x00,0x02,0x57,0x4F,0x57,0x00,0x06,0x08,0x00,0x00,
0x00,0x00,0x00,0x64,0x00,0x0F,0x00,0x00,0x0D,0x00,
0x00,0x00,0x23,0x00,0x00,0x64,0x00,0x00,0x64,0x00
首先100换成16进制,查到对应的16进制是64
然后int类型四个字节,小端存储应该为 0x64,0x00,0x00,0x00
char arr[100] = {
0x00,0x01,0x02,0x03,0x04,0x05,0x16,0x17,0x07,0x09,
0x00,0x20,0x10,0x03,0x03,0x0C,0x00,0x00,0x44,0x00,
0x00,0x33,0x00,0x47,0x0C,0x0E,0x00,0x0D,0x00,0x11,
0x00,0x00,0x00,0x02,0x64,0x00,0x00,0x00,0xAA,0x00,
0x00,0x00,0x64,0x10,0x00,0x00,0x00,0x00,0x00,0x00,
0x00,0x00,0x02,0x00,0x74,0x0F,0x41,0x00,0x00,0x00,
0x01,0x00,0x00,0x00,0x05,0x00,0x00,0x00,0x0A,0x00,
0x00,0x02,0x57,0x4F,0x57,0x00,0x06,0x08,0x00,0x00,
0x00,0x00,0x00,0x64,0x00,0x0F,0x00,0x00,0x0D,0x00,
0x00,0x00,0x23,0x00,0x00,0x64,0x00,0x00,0x64,0x00
};
int nlength = 96;
void PrintArray()
{
for (int i = 0; i < nlength; i++)
{
int* a = (int*)&arr[i+1];
if (0x64 == *a)
{
printf("%x\n", arr);
printf("address:%x,data:%x\n", a, *a);
}
}
}
结果:
此题关键点在于for里面第一行的char* 转 int*,还有理解小端存储。
void PrintAddress()
{
printf("%x\n", arr);
printf("%x\n", arr + 1);
int* a = (int*)&arr[0];
printf("%x\n", a);
printf("%x\n", a + 1);
}
可以很清楚的看出,char类型变量加1是加一个字节,int类型变量加1时加四个字节。
还不清楚的,,,Em…自己试试不强转打印出来什么样子叭