字节序相关问题简单总结,LSB与MSB

细细碎碎的知识点还真是不少啊,今天总结下通信中的数据字节序的问题。

先来认识名词:

MSB:Most Significant Bit.    “最高有效位”

LSB:Least Significant Bit.    “最低有效位”

大端模式:Big Endian.

小端模式:Little Endian.

关于MSB和LSB的东西很简单,MSB指一个数据的二进制表示的最高有效位,LSB指数据的最低有效位,举个栗子看:

1(MSB)001 1011(LSB)

看到了吧,有点类似于十进制,如:13265(一万三千二百六十五),其中万位的1就是MSB,个位的5就是LSB。

好了,这个就这样了。下面是大小端的区别。

大端模式:一个多字节数据的高字节在前,低字节在后,以数据 0x1234ABCD 看例子:

低地址   --------------------->   高地址

+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-

|    12    |    34    |    AB    |    CD    |

+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-

小端模式:一个多字节数据的低字节在前,高字节在后,仍以 0x1234ABCD 看:

低地址   --------------------->   高地址

+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-

|    CD    |    AB   |    34    |    12    |

+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-

以上的例子应该比较形象了吧,大家可能会感觉大端模式比较符合人类的习惯啊,存储的顺序和直观理解的顺序是一样的。X86架构的CPU好想都是小端模式的....

在项目编程中,我个人接触的都是小端模式,在传输数据的时候,组帧时都是把低字节数据放在数组的前边的,所以,不要太仇视小端模式。

协议中如果写 “LSB first” ,这就是指数据传输时采用小端模式,所以,组帧不要错了哦。

再附加一下怎么判断自己的PC是大端模式还是小端模式,看代码:

 1 #include <stdio.h>
 2 int main()
 3 {
 4     typedef union{
 5         int a;
 6         char b;
 7     }UN_TEST;    /* 定义一个联合体数据类型 */
 8
 9     UN_TEST d;
10     d.a = 1;
11     if(d.b == 1)
12     {
13         printf("Little Endian\n");
14     }
15     else
16     {
17         printf("Big Endian\n");
18     }
19
20     return 0;
21 }

联合体的数据元素共用内存,所以你给int元素赋个1,如果是小端模式,它的存储就是 “ 01 00 00 00 ” 这样的;如果是大端模式,就是 “ 00 00 00 01 ” 这样的,所以通过判断char元素的值(共用内存,所以这个值占用的是第一个字节的地址)就可以得到了。

时间: 2024-10-10 16:22:06

字节序相关问题简单总结,LSB与MSB的相关文章

【转】[c/c++ ]字节序与大小端转换--不错

原文网址:http://blog.csdn.net/kuai0705/article/details/20841133 注明: 以下内容均为学习内容整理,记录,便于自己学习,并非完全意义上的自产,如有感到不适,请联系我 一.多字节值及字节序 1.brief 现在有一个数字 65430,这个数字在二进制的内存中一个字节无法完全存下,存储这个数字需要1个字节以上的空间.这样的值被称为多字节量(multi-byte quantity). 65430在内存中由两个字节表示:0xFF 和 0x96 ,其中

字节序问题

1. 在设计计算机时,有两个不同的体系结构来处理内存存储区,他们被称为大字节序和小字节序.字节序是一个处理器架构特性,用于指示像整数这样大数据类型的内部字节顺序.几乎所有的机器上,多字节对象都被存储为连续的字节序列. 运行在同一台电脑上的进程在在英特尔的计算机上,低位字节被优先存储.这意味着像 0x1234 十六进制单词存储作为 (0x34 0x12) 在内存中.对于四个字节的值 :例如,0x12345678 将存储为 (0x78 0x56 0x34 0x12)."较大的一端在"这样做

socket概述和字节序、地址转换函数

一.什么是socket socket可以看成是用户进程与内核网络协议栈的编程接口. socket不仅可以用于本机的进程间通信,还可以用于网络上不同主机的进程间通信. socket API是一层抽象的网络编程接口,适用于各种底层网络协议,如IPv4.IPv6,以及以后要讲的UNIX Domain Socket.然而,各种网络协议的地址格式并不相同,如下图所示: IPv4和IPv6的地址格式定义在netinet/in.h中,IPv4地址用sockaddr_in结构体表示,包括16位端口号和32位IP

理解字节序 大端字节序和小端字节序

1. 计算机硬件有两种储存数据的方式:大端字节序(big endian)和小端字节序(little endian). 举例来说,数值0x2211使用两个字节储存:高位字节是0x22,低位字节是0x11. 大端字节序:高位字节在前,低位字节在后,这是人类读写数值的方法. 小端字节序:低位字节在前,高位字节在后,即以0x1122形式储存. 同理,0x1234567的大端字节序和小端字节序的写法如下图. 2. 我一直不理解,为什么要有字节序,每次读写都要区分,多麻烦!统一使用大端字节序,不是更方便吗?

最简单的方式教你理解大小端字节序

学过编程的人都应该知道大小端字节序的概念,但是很多时候,总是把他们弄混,这是整理出来的一份很简单的方式理解字节序的文章,废话不多说,这里直接入正题. 什么是字节序? 字节序,简单来说,就是指的超过一个字节的数据类型在内存中存储的顺序 那么就很明显了,像char这样的类型,肯定不存在字节序的问题了. 字节序分为哪几类? 大端字节序: 高位字节数据存放在低地址处,低位数据存放在高地址处: 小段字节序: 高位字节数据存放在高地址处,低位数据存放在低地址处: 网络字节序: TCP/IP协议传输数据时,字

网络字节序与主机字节序

最近在项目开发过程中,需要在采用JAVA作为语言的服务器与采用C++作为语言的服务器间进行通信,这就涉及到这两种语言间数据类型的转换以及网络字节序与主机字节序的区别.该文主要说说网络字节序和主机字节序的区别以及Little endian与Big endian的概念.其实编程的事就比较简单了   我也懒得写了,直接引用了我觉得写的挺好的两篇文章: 什么是Big Endian和Little Endian? 来源:http://blog.ednchina.com/qinyonglyz/194674/m

网络字节序与主机字节序 高低位

最近在项目开发过程中,需要在采用JAVA作为语言的服务器与采用C++作为语言的服务器间进行通信,这就涉及到这两种语言间数据类型的转换以及网络字节序与主机字节序的区别.该文主要说说网络字节序和主机字节序的区别以及Little endian与Big endian的概念.其实编程的事就比较简单了   我也懒得写了,直接引用了我觉得写的挺好的两篇文章: 什么是Big Endian和Little Endian? 来源:http://blog.ednchina.com/qinyonglyz/194674/m

PHP: 深入pack/unpack 字节序

http://my.oschina.net/goal/blog/195749?p=1 目录[-] 写在前面的话 什么是字节序 MSB和LSB 大端序 小端序 网络字节序 主机字节序 总结 pack/unpack详解 格式字符翻译 格式字符详解 unpack的用法 一些例子 PHP作为一门为web而生的服务器端开发语言,被越来越多的公司所采用.其中不 乏大公司,如腾迅.盛大.淘米.新浪等.在对性能要求比较高的项目中,PHP也逐渐演变成一门前端语言,用于访问后端接口.或者不同项目之间需要共享数据 的

字节序详解

一.字节序定义 字节序,顾名思义字节的顺序,再多说两句就是大于一个字节类型的数据在内存中的存放顺序(一个字节的数据当然就无需谈顺序的问题了). 其实大部分人在实际的开发中都很少会直接和字节序打交道.唯有在跨平台以及网络程序中字节序才是一个应该被考虑的问题. 在所有的介绍字节序的文章中都会提到字节序分为两类:Big-Endian和Little-Endian.引用标准的Big-Endian和Little-Endian的定义如下: a) Little-Endian就是低位字节排放在内存的低地址端,高位