大字节序、小字节序原理说明及各操作系统的判断方法

多说无益,绕的人头晕,看个地址就明白了:

大字节序:把高有效位放在低地址段,例如在按字节寻址的存储器中往地址 0x0001 存放值 0x12345678,在存储器中为
     地址             数值
     0x0004        0x78
     0x0003        0x56
     0x0002        0x34
     0x0001        0x12

小字节序:把低有效位放在低地址段,例如在按字节寻址的存储器中往地址 0x0001 存放值 0x12345678,在存储器中为
     地址             数值
     0x0004        0x12
     0x0003        0x34
     0x0002        0x56
     0x0001        0x78

现在主流的CPU,intel系列的是采用的little endian的格式存放数据的。

 

判定方法:

    很多语言自带函数,但Linux还没找到,写个函数如下判断:

 

bool  IsLittleEndian()
{
    union
    {
        
long  Long;
        
char  Char[ sizeof ( long )];
    } u;

    u.Long 
=   1 ;
    
if  (u.Char[ 0 ==   1 )
    {
        
return   true ;
    }
    
else   if  (u.Char[ sizeof ( long -   1 ==   1 )
    {
        
return   false ;
    }
    
else
    {
        
throw   " Unknown Addressing! " ;
    }
}

 

 再上一个大小字节序转换函数:

 

void  EndianConvert(unsigned  int *  value)
{
    
* value  =   * value << 24   |  (( * value & 0xFF00 ) << 8 |  (( * value & 0xFF0000 ) >> 8 |  (( * value & 0xFF000000 ) >> 24 );
}

 

 

 

参考:

http://www.dnbcw.com/biancheng/c/esbu62056.html

http://hi.baidu.com/wbwssb/blog/item/7114224df46c6dc6d1c86ac6.html

转载于:https://www.cnblogs.com/khler/archive/2010/08/26/1809129.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值