专栏中心

EEPW首页 > 专栏 > 判断机器的大小端问题

判断机器的大小端问题

发布人:北京华清远见 时间:2013-11-13 来源:工程师 发布文章

作者:陈老师,华清远见嵌入式学院讲师。

用C语言写程序时需要知道是大端模式还是小端模式。

所谓的大端模式(BE big-endian),是指数据的低位保存在内存的高地址中,而数据的高位,保存在内存的低地址中(低对高,高对高)。最直观的字节序,因为不要考虑对应关系 只需要把内存地址从左到右按照由低到高的顺序写出,把值按照通常的高位到低位的顺序写出,两者对照,一个字节一个字节的填充进去。

所谓的小端模式(LE little-endian),是指数据的低位保存在内存的低地址中,而数据的高位保存在内存的高地址中(低对低,高对高)。最符合人的思维的字节序,因为从人的第一观感来说,低位值小,就应该放在内存地址小的地方,也即内存地址低位。反之,高位值就应该放在内存地址大的地方,也即内存地址高位

为什么会有大小端模式之分呢?这是因为在计算机系统中,我们是以字节为单位的,每个地址单元都对应着一个字节,一个字节为8bit。但是在C语言中除了8bit的char之外,还有16bit的short型,32bit的long型(要看具体的编译器),另外,对于位数大于8位的处理器,例如16位或者32位的处理器,由于寄存器宽度大于一个字节,那么必然存在着一个如果将多个字节安排的问题。因此就导致了大端存储模式和小端存储模式。

在实际编程中,我们可能会遇到判断一个平台是大端的,还是小端的。下面总结了几个常见的判断思路。

思路一:联合体union的存放顺序是所有成员都从低地址开始存放,利用该特性就可以轻松地获得了。

CPU对内存采用Little-endian还是Big-endian模式读写:

int checkCPU( )
{
        {
              union w
              {
                     int a;
                     char b;
              } c;
              c.a = 1;
              return(c.b ==1);
       }
}

思路二:利用数据类型转换的截断特性:

int i = 0x00000001;
if(*(char*)&i)
        puts("little");
        else
puts("big);

思路三:在linux内核中实现的方法:

static union
{
       charc[4];
       unsigned long l;
}endian_test = {{'l','?','?','b'}};
#define ENDIANNESS((char)endian_test.l)

文章来源:华清远见嵌入式学院原文地址:http://www.embedu.org/Column/Column762.htm

更多相关嵌入式免费资料查看华清远见讲师博文>>


专栏文章内容及配图由作者撰写发布,仅供工程师学习之用,如有侵权或者其他违规问题,请联系本站处理。 联系我们

关键词:

相关推荐

使用AI增强型EDA工具重新构想电动汽车设计

EasyARM1138嵌入式专题讲座

视频 2009-12-02

SI 表示,全球电子产品生产不稳定

Intel ATCA

如何防止生成式AI中的对抗性提示?

智能计算 2025-10-31

SPICE集成模型:栅极驱动器对开关损耗的影响

Intel IOP 80219&IOP 80331 IO处理器

AI服务器明年出货看增20%

Intel Flash芯片I28F320C硬件手册

Vicor 电源模块 VI 的基本功能介绍

视频 2009-12-01

安世半导体引发全球供应链危机将在11月集中爆发

恒忆 Krypto 密码访问

视频 2009-12-14

什么是支持 6G 网络的可重构智能表面 (RIS)

Keli C51软件开发环境v6.02

中国推出首个国家级汽车芯片测试平台,推动科技主权

更轻易的LED照明温度控制

视频 2009-12-02

谐波工程师开发指南

传感器与换能器技术综述

闪存安全功能保护您的知识产权

视频 2009-12-14

K149资料和原理图

更多 培训课堂
更多 焦点
更多 视频

技术专区