大小端示例-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是平台无关的,默认是大端。在网络上传输数据普遍采用的都是大端。