MSB与LSB

Most Significant Bit, Last(Least) Significant Bit

最高有效位(MSB) 
指二进制中最高值的比特。在16比特的数字音频中,其第1个比特便对16bit的字的数值有最大的影响。例如,在十进制的15,389这一数字中,相当于万数那1行(1)的数字便对数值的影响最大。比较与之相反的“最低有效位”(LSB)。
MSB高位前导,LSB低位前导。

谈到字节序的问题,必然牵涉到两大CPU派系。那就是Motorola的PowerPC系列CPU和Intel的x86系列CPU。PowerPC系列采用big endian方式存储数据,而x86系列则采用little endian方式存储数据。那么究竟什么是big endian,什么又是little endian呢?

     其实big endian是指低地址存放最高有效字节(MSB),而little endian则是低地址存放最低有效字节(LSB)。

     用文字说明可能比较抽象,下面用图像加以说明。比如数字0x12345678在两种不同字节序CPU中的存储顺序如下所示:

Big Endian

   低地址                                            高地址
   ----------------------------------------->
   +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
   |     12     |      34    |     56      |     78    |
   +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+

Little Endian

   低地址                                            高地址
   ----------------------------------------->
   +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
   |     78     |      56    |     34      |     12    |
   +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+

     从上面两图可以看出,采用big endian方式存储数据是符合我们人类的思维习惯的。而little endian,!@#$%^&*,见鬼去吧 -_-|||

     为什么要注意字节序的问题呢?你可能这么问。当然,如果你写的程序只在单机环境下面运行,并且不和别人的程序打交道,那么你完全可以忽略字节序的存在。但是,如果你的程序要跟别人的程序产生交互呢?在这里我想说说两种语言。C/C++语言编写的程序里数据存储顺序是跟编译平台所在的CPU相关的,而J***A编写的程序则唯一采用big endian方式来存储数据。试想,如果你用C/C++语言在x86平台下编写的程序跟别人的J***A程序互通时会产生什么结果?就拿上面的0x12345678来说,你的程序传递给别人的一个数据,将指向0x12345678的指针传给了J***A程序,由于J***A采取big endian方式存储数据,很自然的它会将你的数据翻译为0x78563412。什么?竟然变成另外一个数字了?是的,就是这种后果。因此,在你的C程序传给J***A程序之前有必要进行字节序的转换工作。

     无独有偶,所有网络协议也都是采用big endian的方式来传输数据的。所以有时我们也会把big endian方式称之为网络字节序。当两台采用不同字节序的主机通信时,在发送数据之前都必须经过字节序的转换成为网络字节序后再进行传输。ANSI C中提供了下面四个转换字节序的宏。
·BE和LE一文的补完

我在8月9号的《Big Endian和Little Endian》一文中谈了字节序的问题,原文见上面的超级链接。可是有朋友仍然会问,CPU存储一个字节的数据时其字节内的8个比特之间的顺序是否也有big endian和little endian之分?或者说是否有比特序的不同? 

     实际上,这个比特序是同样存在的。下面以数字0xB4(10110100)用图加以说明。 

Big Endian

   msb                                                         lsb
   ---------------------------------------------->
   +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
   |   1  |   0  |   1  |   1  |   0  |   1  |   0  |   0  |
   +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+

Little Endian

   lsb                                                         msb
   ---------------------------------------------->
   +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
   |   0  |   0  |   1  |   0  |   1  |   1  |   0  |   1  |
   +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+


     实际上,由于CPU存储数据操作的最小单位是一个字节,其内部的比特序是什么样对我们的程序来说是一个黑盒子。也就是说,你给我一个指向0xB4这个数的指针,对于big endian方式的CPU来说,它是从左往右依次读取这个数的8个比特;而对于little endian方式的CPU来说,则正好相反,是从右往左依次读取这个数的8个比特。而我们的程序通过这个指针访问后得到的数就是0xB4,字节内部的比特序对于程序来说是不可见的,其实这点对于单机上的字节序来说也是一样的。 

     那可能有人又会问,如果是网络传输呢?会不会出问题?是不是也要通过什么函数转换一下比特序?嗯,这个问题提得很好。假设little endian方式的CPU要传给big endian方式CPU一个字节的话,其本身在传输之前会在本地就读出这个8比特的数,然后再按照网络字节序的顺序来传输这8个比特,这样的话到了接收端不会出现任何问题。而假如要传输一个32比特的数的话,由于这个数在littel endian方存储时占了4个字节,而网络传输是以字节为单位进行的,little endian方的CPU读出第一个字节后发送,实际上这个字节是原数的LSB,到了接收方反倒成了MSB从而发生混乱。


转载于:http://www.cnblogs.com/shuaifeng/archive/2009/12/23/1630195.html

### MSB LSB 的概念 在二进制表示中,MSB (Most Significant Bit) 表示最高有效位,而 LSB (Least Significant Bit) 则指最低有效位。这些术语通常用于描述数据存储、传输以及隐写术等领域中的位操作。 #### 高效理解 MSB LSB - **MSB** 是二进制数中最左侧的位,在数值计算中具有最大的权重[^1]。例如,对于一个 8 位二进制数 `10110101`,其 MSB 就是左起第一位的 `1`。 - **LSB** 是最右侧的位,代表最小的权值[^1]。在同一例子中,LSB 即为右起第一位的 `1`。 #### 应用场景分析 在隐写技术领域,如引用所提到的内容,zsteg 工具通过提取图像像素颜色通道的不同组合来查找隐藏的信息。具体来说: - 使用 **LSB 方法** 可以嵌入少量的数据到图片的颜色分量里而不明显改变视觉效果。比如命令 `b2,g,lsb,xy` 提取绿色通道的 LSB 数据并得到文件路径或者编码后的字符串。 ```bash $ zsteg -a example_image.png ``` - 对于 **MSB 方法**,它涉及的是较高权重的部分,可能影响更显著的颜色变化,因此适合某些特定场合下的信息传递。像输出 `"UUuUUWUUUUUuUUUU"` 或者重复字符序列可能是基于此原理产生的结果。 #### C语言实现简单演示 下面是一个简单的C程序片段展示如何访问整型变量内的单个比特位置(假设小端模式下),这有助于直观感受MSBLSB的位置关系[^2]: ```c #include <stdio.h> int main() { unsigned char byte = 0b10110101; // 假设这是我们的测试字节 printf("Byte Value: %d\n", byte); int i; for(i=7;i>=0;i--){ // 打印每一位的状态 if(byte & (1<<i)){ putchar('1'); }else{ putchar('0'); } } return 0; } ``` 该代码会打印出原始定义好的八位二进制串形式,其中首位即为我们讨论过的MSB部分。 ### 结论总结 无论是理论层面还是实际应用当中,掌握好关于MSBLSB的知识点都是非常重要的基础技能之一。它们不仅限于计算机科学内部的应用范围广袤无垠之外,在其他学科交叉融合过程中也发挥着不可替代的作用。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值