iOS简单判断大小端字节序

大小端定义

大端模式(Big-endian),是指数据的高字节,保存在内存的低地址中,而数据的低字节,保存在内存的高地址中(网络上一般都是采用大端模式)
小端模式(Little-endian),是指数据的高字节保存在内存的高地址中,而数据的低字节保存在内存的低地址中
例如
int a =1;
为0x 00 00 00 01,一个有32bit,4个Byte,内存地址是连续的,如在起始地址为0x400001的内存地址中,
在大端模式下
第一位为0x00(地址为0x400001)
第二位为0x00(地址为0x400002)
第三位为0x00(地址为0x400003)
第四位为0x01(地址为0x400004),高地址保存低字节。
在小端模式下就相反。

判断大小端字节序代码

int checkCPU()
{
    union w
    {
        int a;//在ios中,4 Byte
        char b;//在ios中,1 Byte
    } c;
    c.a = 1;
    return(c.b ==1);//如果c.b == 1,表示第一位是0x01,那就是小端,如果返回0,就是大端
}

union简述

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

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

你可能感兴趣的:(iOS简单判断大小端字节序)