大端 / 小端,三种判断方法

1.什么是大端 / 小端?
2.为什么会有大小端之分呢?
3.怎么判断当前机器的字节序?

什么是大端 / 小端?
大端(存储)模式,是指数据的低位保存在内存的高地址中,而数据的高位保存在内存的低地址中
小端(存储)模式,是指数据的低位保存在内存的低地址中,而数据的高位保存在内存的高地址中

为什么会有大小端之分呢?
因为在计算机系统中,我们以字节为存储单元,每个地址单元都对应着一个字节,一个字节为8bit。而在C语言中,不仅仅是一个字节来存储一个数据,除了一个字节的char,还有两个字节的short,四个字节的int等等(看具体编译器)。另外,对于位数大于8位的处理器,例如32位的处理器,由于寄存器的宽度大于一个字节,那么就有如何将多个字节进行排布的问题,于是就出现了大小端的问题。下面举个栗子:(32位机)
这里写图片描述

怎么测试我的电脑是小端模式还是大端模式呢?
1.将int 48存起来,然后取得其地址,再将这个地址转为char* 这时候,如果是小端存储,那么char*指针就指向48;
48对应的ASCII码为字符‘0’;

void judge_bigend_littleend1()
{
    int i = 48;
    int* p = &i;
    char c = 0;
    c = *((char*)p);

    if (c == '0')
        printf("小端\n");
    else
        printf("大端\n");
}

2.定义变量int i=1;将 i 的地址拿到,强转成char*型,这时候就取到了 i 的低地址,这时候如果是1就是小端存储,如果是0就是大端存储。

void judge_bigend_littleend2()
{
    int i = 1;
    char c = (*(char*)&i);

    if (c)
        printf("小端\n");
    else
        printf("大端\n");
}

3.定义联合体,一个成员是多字节,一个是单字节,给多字节的成员赋一个最低一个字节不为0,其他字节为0 的值,再用第二个成员来判断,如果第二个字节不为0,就是小端,若为0,就是大端。

void judge_bigend_littleend3()
{
    union
    {
        int i;
        char c;
    }un;
    un.i = 1;

    if (un.c == 1)
        printf("小端\n");
    else
        printf("大端\n");
}
### 回答1: 大小端指的是数据在内存中存储的顺序,大端模式是高位字节存储在低地址,小端模式是高位字节存储在高地址。在Linux下,可以使用以下代码判断当前机器的大小端模式: ``` #include <stdio.h> int main() { unsigned int x = 0x12345678; char *c = (char*)&x; if (*c == 0x12) { printf("Big Endian\n"); } else { printf("Little Endian\n"); } return 0; } ``` ### 回答2: 在Linux中,判断系统是大端还是小端可以通过以下方法: 1. 使用C语言的方式判断:可以使用联合体的方式来判断大小端。可以创建一个包含一个char类型和一个int类型的联合体,然后将这个联合体的char和int成员的值分别设置为1,然后通过判断char成员的值来确定系统的字节序。若为1,则为小端;若为0,则为大端。 ```c #include <stdio.h> int main() { union { char c; int i; } endian; endian.i = 1; if (endian.c == 1) { printf("小端字节序\n"); } else { printf("大端字节序\n"); } return 0; } ``` 2. 使用命令行工具:在Linux终中使用命令`lscpu`可以获取CPU的详细信息,其中有一项是"Byte Order",如果显示为"Little Endian"则表示是小端字节序,如果显示为"Big Endian"则表示是大端字节序。 综上所述,以上两种方法都可以在Linux中判断大小端。 ### 回答3: 在Linux中,可以通过以下方法判断当前系统的字节序大端(Big Endian)还是小端(Little Endian)。 方法一:使用C语言编写一个小程序进行判断。 ```c #include<stdio.h> int main() { unsigned int num = 1; char *p = (char *)&num; if (*p == 1) { printf("该系统为小端字节序\n"); } else { printf("该系统为大端字节序\n"); } return 0; } ``` 该程序定义了一个无符号整型变量`num`并给其赋值为1,然后通过指针`p`来指向`num`的地址。由于整型在内存中是以字节的形式存储的,我们将首地址的字节与1进行比较,如果相等,则说明是小端字节序,否则为大端字节序方法二:使用命令行查看系统的字节序。 在Linux中,我们可以通过命令`lscpu`来查看系统的相关信息,其中包括字节序。在终中输入如下命令: ``` lscpu | grep "Byte Order" ``` 如果输出结果为`Byte Order: Little Endian`,则说明系统为小端字节序。如果输出结果为`Byte Order: Big Endian`,则说明系统为大端字节序。 以上两种方法可以帮助我们在Linux中判断大小端
评论 11
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值