字节序测试函数

字节排序函数
考虑一个16位的整数,它由2个字节组成,内存中存储这两个字节有两种方法,一种是将低序字节存储在起始地址,这称为小端(little–endian)字节排序;另一种是将高序字节存储在起始地址,这称为大端(big–endian)字节序。如图所示:
这里写图片描述
在该图中,我们在顶部标明内存增长的方向为从右到左,在底部标明内存地址增长的方向为从左到右。我们还标明最高有效位(MSB)是这个16位值最左边位,最低有效位(LSB)是这个16位值最右边一位。
实验代码如下:

#include "unp.h"
int  main(int argc , char **argv)
{
    union {
        short s;
        char c[sizeof(short)];
    }un;

    un.s = 0x0102;
    printf("%s:  ", CPU_VENDOR_OS);
    if(sizeof(short) == 2)
    {
        if(un.c[0] == 1 && un.c[1] == 2)
            printf("big--ending\n");
        else if(un.c[0] == 2 && un.c[1] == 1)
            printf("little--ending\n");
        else 
                printf("unkown\n");
    }else
    printf("sizeof(short) = %d\n", sizeof(short));
    exit(0);
}

我们在一个短整型变量中个存放2个字节的值0x0102,然后查看它的两个连续字节c[0]和c[1],以确定字节序。
字符串CPU_VENDOR_OS由GNU的autoconf程序在配置本书中的软件是确定的,他标识CPU的型号,厂家,和操作系统版本,运行效果如下:

unbuntu# ./a.out 
i686-pc-linux-gnu:  little--ending
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值