一字节序
在进行CAN总线通信设计或者测试过程中,经常看到CAN总线信号的编码格式有两种定义:Intel格式与Motorola格式。
字节序的问题,必然牵涉到两大CPU派系。那就是Motorola的PowerPC系列CPU和Intel的x86系列CPU。PowerPC系列采用big endian方式存储数据,而x86系列则采用little endian方式存储数据
字节序分为两类:Big-Endian(Motor)和Little-Endian(Intel)也就是大端序和小端序。
大端模式(Motor):数据的低位保存在内存的高地址中,数据高位保存在内存的低地址中。
小端模式(Intel):数据的低位保存在内存的低地址中,数据高位保存在内存的高地址中。
二 存放方式举例:
以一个32byte 的int型变量a=0x12345678举例:
各自优势:
大端序:符号位的判断在第一个字节,容易判断数据的正负
小端序:长度为1,2,4字节的数,排列方式都是一样的,数据类型转换非常方便。
三大小端模式分类的原因
这是因为在计算机系统中,我们是以字节为单位的,每个地址单元都对应着一个字节,一个字节为8bit。但是在C语言中除了8bit的char之外,还有16bit的short型,32bit的long型(要看具体的编译器),另外,对于位数大于8位的处理器,例如16位或者32位的处理器,由于寄存器宽度大于一个字节,那么必然存在着一个如果将多个字节安排的问题。
程序在单机运行的时候是可以忽略字节序的存在的。但是如果要和别人的程序进行交互,那就要考虑字节序的存在了。
- C/C++语言编写的程序里数据存储顺序是跟编译平台所在的CPU相关的,而现在比较普遍的 x86 处理器是 Little Endian
- JAVA编写的程序则唯一采用 Big Endian 方式来存储数据
当这两种语言进行交互的时候,是要考虑字节序的存在的。通常会把这两种数据分别都转成网络序再进行传输。