Intel 64/x86_64/IA-32/x86处理器 - 通用指令(3) - 逻辑指令/移位指令
Logical Instructions
逻辑指令执行基本的“与、或、非、异或”操作,操作数可以是字节,单字和双子值。
指令 |
描述 |
AND |
对操作数执行按位逻辑“与”操作 |
OR |
对操作数执行按位逻辑“或”操作 |
XOR |
对操作数执行按位逻辑“异或”操作(exclusive OR) |
NOT |
对操作数执行按位逻辑“非”操作 |
对与NOT指令与NEG指令做一点说明。
NOT指令对操作执行按位“取非”操作,这种操作也被称为1的补码求负操作(国内译做反码)。例如对4位的二进制0010B数执行NOT 0010B (对应十进制+2)之后的结果是 1101(这种表示对应的十进制数是-2),这种表示法被称为1的补码,因为将前面的+2与-2相加,会得到1111(表示十进制的-0),而0000也表示十进制+0,这样在1的补码表示法中,十进制0由两种表示法1111和0000。1的补码表示法常用于网络协议报头中计算校验和。
NEG指令对操作数执行2的补码求负操作。例如NEG 0010B(对应十进制+2)会得到1110。在2的补码表示法中1110B对应的十进制数是-2。2的补码表示法中十进制0只有一种表示法,即0000B;这种表示法常用于计算机的处理器中表示数值。
所以对同一个操作数(例如0010B),NOT指令与NEG指令执行的结果是不相同的。
Shift and Rotate Instructions
移位与循环移位指令对操作数按位执行移位与循环移位操作,操作时可以是字节,单字和双字。
指令 |
描述 |
SAR |
算术右移(每右移1比特位,等价于有符号数除以2) |
SHR |
逻辑右移(每右移1比特位,等价于无符号数除以2) |
SAL/SHL |
算术左移/逻辑左移(每左移1比特位,等价于数值乘以2) |
SHRD |
双精度右移 |
SHLD |
双精度左移 |
对SHLD与SHRD指令做一点说明。这两条指令都是3操作数指令,将源操作数中的某些比特位移到目标操作数中。SHLD指令的操作如下图所示。SHRD的操作类似(TODO: 以后补上)。
指令 |
描述 |
ROR |
循环右移 |
ROL |
循环左移 |
RCL |
带进位的循环左移 |
RCR |
带进位的循环右移 |