Chinaunix首页 | 论坛 | 博客
  • 博客访问: 822810
  • 博文数量: 92
  • 博客积分: 1498
  • 博客等级: 上尉
  • 技术积分: 993
  • 用 户 组: 普通用户
  • 注册时间: 2009-09-18 18:31
文章分类

全部博文(92)

文章存档

2013年(2)

2012年(3)

2011年(3)

2010年(61)

2009年(23)

分类: LINUX

2010-07-26 16:44:15

以前某门课程的时候听说过字节序的问题,就是因为操作系统和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
 * 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$ 

阅读(6510) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~