#include<stdio.h>
int main()
{
int a=1;
char *p=(char *)&a;
if(*p==1)
{
printf("小端模式\n");
}
else
{
printf("大端模式\n");
}
return 0;
}
当初没有理解这段代码的原因是没有看懂为什么要用char型指针,因为char是1字节,int是4字节。我们假设其中一个字节的数据,就能知道另外三个字节的数据了,从而验证猜想。也就是char *p=(char *)&a这句。
当定义了a=1时;如果是小端模式且char *p=(char *)&a指针指向了内存低地址处
| 0000 0000 | 内存高地址 |
| 0000 0000 | |
| 0000 0000 | |
| 0000 0001 | 内存低地址<—— |
*p=就是把里面的数取出来,因为*p==1,故是小断模式
如果大端模式且char *p=(char *)&a指针指向了内存低地址处
| 0000 0001 | 内存高地址 |
| 0000 0000 | |
| 0000 0000 | |
| 0000 0000 | 内存低地址<—— |
如果 *p不等于1,就是大端模式。
这篇博客通过一个简单的C程序来解释如何判断计算机的字节序是小端模式还是大端模式。核心在于将整型变量a的地址赋值给字符型指针p,然后检查指针所指向的第一个字节是否为1。在小端模式下,最低有效字节存储在内存的低地址,因此如果*p等于1,则为小端模式;反之,在大端模式下,最高有效字节位于低地址,*p不会等于1。这种方法帮助开发者理解不同平台上的字节存储方式。
3173

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



