C语言判断大小端两种方式

大小端

大端:高位存低地址        //1->0x10000000

小端:高位存高地址        //1->0x00000001

联合体判断大小端

因为联合体是共用内存的,因此可以定义一个int型的和一个char型的,给int型赋值,通过char型访问,判断大小端。

#include <stdio.h>
union Un
{
    int a;
    char b;
};

int main()
{
    union Un un;
    un.a = 1; // 此时内存空间为0x00000001
    int num = un.b;
    if (num == 1)
    {
        printf("小端\n");
    }
    else
    {
        printf("大端\n");
    }
}

访问方式判断大小端

定义一个int型的数,通过char去访问

#include <stdio.h>
int main()
{
    int a = 0x11223344;
    char num = (char)a;
    if (num == 0x44)
    {
        printf("小端\n");
    }
    else
    {
        printf("大端\n");
    }
}

### C语言判断系统字节序(大端或小端) #### 方法一:使用指针 一种常见的方法是定义一个多字节数值,然后通过`char *`类型的指针访问其第一个字节。如果该字节等于原始数值,则表示这是个小端机器;反之则是大端。 ```c #include <stdio.h> int main() { unsigned int value = 0x12345678; unsigned char *ptr = (unsigned char *)&value; if (*ptr == 0x78) { printf("Little endian\n"); } else { printf("Big endian\n"); } return 0; } ``` 这种方法基于指针操作来获取整数的第一个字节[^2]。 #### 方法二:使用联合体 另一种更优雅的方式是借助C语言中的联合体结构。由于联合体内所有成员共享同一块内存空间,在向其中一个成员赋值后再读取另一个不同类型的成员即可得知字节顺序: ```c #include <stdio.h> union EndianTest { uint32_t number; uint8_t bytes[sizeof(uint32_t)]; }; void check_endianess() { union EndianTest test; test.number = 0x12345678; if (test.bytes[0] == 0x78 && test.bytes[1] == 0x56 && test.bytes[2] == 0x34 && test.bytes[3] == 0x12) { puts("Little-endian system."); } else if (test.bytes[0] == 0x12 && test.bytes[1] == 0x34 && test.bytes[2] == 0x56 && test.bytes[3] == 0x78) { puts("Big-endian system."); } } int main(){ check_endianess(); return 0; } ``` 此代码片段展示了如何利用联合体特性来进行字节序检测[^4]。 上述两种方案均能有效地识别目标平台上的字节排列方式,并且具有良好的可移植性和简洁性。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值