简述字节序的概念,并用指针方式,或者共用体(联合体)的方式计算本机是大端还是小端
1. 概念:
1). 字节序是指不同类型的CPU主机,内存存储多字节整数序列的方法
a. float char 字符串没有字节序的说法
b. short int long longlong 有字节序的说法。
2). 字节序分为小端字节序和大端字节序
a. 小端字节序:低序字节存储在低地址上
b. 大端字节序:低序字节存储在高地址上,高序字节存储在低地址上。
2. 用指针方式确认计算机是大端还是小端
实现代码如下:
#include <myhead.h>
int main(int argc, const char *argv[])
{
unsigned int a = 0x87654321;
char *p = (char *)&a;
printf("*p = %#x\n",*p);
if(*p == 0x21)
{
printf("是小端\n");
}
else if(*p == 0x87)
{
printf("是大端\n");
}
return 0;
}
运行结果如下:
ubuntu@ubuntu:com$ ./a.out
*p = 0x21
是小端
3. 用共用体(联合体)方式计算本机是大端还是小端
实现代码:
#include <myhead.h>
typedef union
{
int a;
char b;
} A_t;
int main(int argc, const char *argv[])
{
A_t A;
A.a=0x87654321;
printf("b = %#x\n",A.b);
if(A.b=0x21)
{
printf("是小端\n");
}
else if(A.b = 0x87)
{
printf("是大端\n");
}
return 0;
}
运行结果如下:
ubuntu@ubuntu:com$ ./a.out
b = 0x21
是小端
文章介绍了字节序的概念,包括小端字节序和大端字节序的定义,并提供了两种方法检查计算机是使用小端还是大端字节序:一种是通过指针访问多字节整数的低地址字节,另一种是利用共用体(联合体)直接读取。通过示例代码和运行结果,展示了如何判断本机字节序。

1519

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



