2.3 数据代码的处理与存储
在计算机系统中,数据的处理和存储一般会涉及移位操作、舍入处理、扩展与压缩,以及存储时的大小端模式和边界对齐。
1.移位操作
移位是算术、逻辑运算的又一种基本操作,几乎所有机器指令系统中都设有各类移位操作指令。移位通常分为逻辑移位和算术移位两大类。
(1)逻辑移位
在逻辑移位中,数字代码被当成纯逻辑代码,没有数值含义,因此没有符号与数值变化的概念。
(2)算术移位
在算术移位中,数字代码具有数值含义,而且大多数带有符号位。因此,算术移位中必须保持符号位不变,一个正数在移位后应该还是正数。
①正数补码(包括原码)移位规则:数符不变,空位补0.
②负数补码移位规则:数符不变,左移时空位补0,右移时空位补1.
2.舍入处理
固定字长的数,右移将舍去低位部分。
3.代码的扩展与压缩
计算机中经常会涉及数据字长的扩展与压缩操作。
(1)符号扩展与0扩展
(2)数位压缩
4.大小端存储模式
在计算机系统中存储数据通常以字节为单位,每个地址单元都存储一个字节(8bit)。
(1)大端模式
(2)小端模式
5.数据字的存储对齐
所谓数据字的存储对齐方式,指的是一个多字节数据在进行存储安排的时候,其首字节数据安排的起始地址位置。
(改天补充更多内容。)