大小端示例-arm c51

大小端系列文章https://blog.csdn.net/liming0931/article/details/100016425

MDK(Keil5,STM32F407)C语言:

#include "stm32f4xx.h"



int main(void)

{ 

    int u = 367328153; // 原始数据15 E4 FB 99

    int* k = &u;

    return 0;

}

编译连接然后下载到开发板上,然后启动调试,通过监视窗口可以看到u的地址,然后在内存窗口可以看到字节序是反序的,所以说明STM32F407是小端的。据某些资料说ARM内核是可以设置大小端的,但是STM32是外设自动进入了小端,似乎是无法调整的。

89C52(Keil5)C语言

来一个大端的例子。手头上没有51的开发板,所以用的是软件仿真。

#include <reg52.h>
 
int main()
{
    int longbit = sizeof(long);
     
    long u = 367328153; // 原始数据15 E4 FB 99
    long* k = &u;
     
    return 0;
}

注意看了,C52是8位的处理器,long才是4个字节的,看监视窗口longbit的值就知道了(紫色框)。然后再看内存窗口,就会发现u的存储是跟原始数据给的顺序是一样的,所以C51和C52是大端的!!

目前Intel的80x86系列芯片是唯一还在坚持使用小端的芯片,ARM芯片默认采用小端,但可以切换为大端;而MIPS等芯片要么采用全部大端的方式储存,要么提供选项支持大端——可以在大小端之间切换。另外,对于大小端的处理也和编译器的实现有关,在C语言中,默认是小端(但在一些对于单片机的实现中却是基于大端,比如Keil 51C),Java是平台无关的,默认是大端。在网络上传输数据普遍采用的都是大端。

原文地址:https://www.cnblogs.com/CodeWorkerLiMing/p/12007321.html