思路:
明确大小端:
(1)小端:底地址存数据的低位,高地址存数据的高位,用“小小小”概括(小端,小地址,小数据)
(2)大端:底地址存数据的高位,高地址存数据的低位
如图示:

程序思路:
(1)思考数据的存储方式以及地址排列,int型 在32 位操作系统下 占有 4字节,
char 型 占有1字符,因此可以利用char 型指针判断 int 型地址与数据
(2)如: 若有整形 int b=0x 77 ff 10 01,则我们知 0x 01 ,0x 10,0x ff ,0x 77分别各为一字节,
因此用char 型指针的值 与 其 解应用 后的值 和b 做判断
头文件:
#pragma once
#include
void test()
{
int tt =0x77ff1001;
char *pp = (char*)&tt;
//输出tt 的信息
printf("\n\ttt:%#X\t &tt:%p \n", tt, &tt);
//输出tt 的下一个字节起始位置
printf("\n\ttt:%#X\t &tt:%p \n", tt, &tt+1);
printf("检验:\n");
// 输出tt 的第一字节的值 ,与地址
printf("\tpp:%#X\t &pp:%p \n\n", *pp, pp);
// 输出tt 的第二字节的值,与地址
printf("\tpt:%#X\t &(pp1):%p \n\n", *(pp + 1), pp + 1);
// 输出tt 的第三字节的值,与地址
printf("\tpt:%#X\t &(pt2):%p \n\n", *(pp + 2), pp + 2);
// 输出tt 的第四字节的值,与地址
printf("\tpt:%#X\t &(pt3):%p \n\n", *(pp + 3), pp + 3);
//输出tt 的下一个字节起始位置
printf("\tpt:%#X\t &(p+t):%p \n\n", *(pp + 4), pp + 4);
}
源文件:
#include"is_big_small.h"
#include
int main()
{
test();
system("pause");
return 0;
}
结果如下:(输出提示中有一点错误:pp为*pp,&pp为 pp >^


3173

被折叠的 条评论
为什么被折叠?



