什么是大端,小端字节序

以前某门课程的时候听说过字节序的问题,就是因为操作系统和CPU的问题,对多字节变量的内存存储顺序不
同。比如一个16位的整数,由两个字节构成,有的系统会将高字节放在内存的低地址,而有的系统则会将高字
节放在内存的高地址上。所以存在字节序的问题,一般大于一个自己的变量的类型的表示方法有两种:小端字
节序(便是变量的内存地址的起始地址存放低字节,高字节顺序存放)和大端字节序(在表示变量的内存地址
的起始地址存放高字节,低字节顺序存放)。
例如变量的值为0xabcd,在大端字节序和小端字节序的系统中二者的存放顺序是不同的,假设存放值0xabcd
的内存地址的起始地址为0,分别如下图所示:

然后我们可以根据下面的例子判断出自己的系统是大端字节序还是小端字节序

/*
 * Copyright (c) 2010-~ zhouyongfei
 *
 * The source code is released for free distribution under the terms of the GNU General Public License
 *
 *
 * Author: alen Chou<zhouyongfei1988@gmail.com>
 * Created Time: 2010年07月26日 星期日 16时13分43秒
 * File Name: test.c
 * Description: 
 * 
 */


#include <stdio.h>
#include <stdlib.h>
/**
 * 联合类型的变量类型,用于测试字节序
 * 成员value的高低端字节可以由成员byte按字节访问
 *
 * */

typedef union{
    unsigned short int value;
    unsigned char byte[2];
}to;

int main(int argc, char *argv[])
{
    to typeorder;
    typeorder.value = 0xabcd;

    if(typeorder.byte[0] == 0xcd&& typeorder.byte[1] == 0xab){
        printf("Low endian byte order"
                "byte[0]:0x%x,byte[1]:0x%x\n",
                typeorder.byte[0],
                typeorder.byte[1]);
    }else if(typeorder.byte[0] == 0xab&& typeorder.byte[1] == 0xcd){
        printf("High endian byte order"
                "byte[0]:0x%x,byte[1]:0x%x\n",
                typeorder.byte[0],
                typeorder.byte[1]);
    }
    return 0;
}



我的机子的运行结果如下:
zhou@zhou:~/test$ ./test
Low endian byte orderbyte[0]:0xcd,byte[1]:0xab
zhou@zhou:~/test$ 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值