如何用最简单的程序判断大小端问题

如何用最简单的程序判断大小端问题,第1张

#include <stdio.h>

union utype

{

    局戚碰int i

    char a

}

void main()

{

    union 仔巧utype u

    u.i = 1

    if (u.a)

        桐谈printf("小端\n")

    else

        printf("大端\n")

}

大端模式(Big-endian),是指数据的高字节,保存在内存的低地址中,而数据的低字节,保存在内存的高地址中(网络上一般困桐码都是采用大端模式)

小端模式(Little-endian),是指数据的高字节保存在内存的高地址中,而数据的低字节保存在内存的低地址中

例如

int a =1;

为0x 00 00 00 01,一个有32bit,4个Byte,内存地址是轮告连续的,如在起始地址为0x400001的内存地址中,

在大端模式下

第一位为0x00(地址为0x400001)

第二位为0x00(地址为0x400002)

第三位为0x00(地址为0x400003)

第四位为0x01(地址为0x400004),高地址保存低字节。

在小端模式下就相反。

在C语言中,关键字union 维护足够的空间来置放多个数据成员中的“一种”,而不是为每一个数据成员汪哪配置空间,在union 中所有的数据成员共用一个空间,同一时间只能储存其中一个数据成员,所有的数据成员具有 相同的起始地址 。例子如下:

union StateMachine

{

char character

int number

char *str

double exp

}

一个union 只配置一个足够大的空间以来容纳最大长度的数据成员,以上例而言,最大长度是double 型态,所以StateMachine 的空间大小就是double 数据类型的大小。


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/yw/12401946.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-25
下一篇 2023-05-25

发表评论

登录后才能评论

评论列表(0条)

保存