(3)逻辑“非”(取反)NOT 对操作数进行按位逻辑”非”操作。 格式: NOT mem/reg 例: NOT CX NOT BYTE PTR[I
格式 NOT mem/reg (3) 逻辑“非”(取反) NOT
(4)逻辑”异或”XOR 对两个操作数按位进行”异或”操作。 格式: XoR dest. src 用途:对reg清零(自身异或) 把reg/mem的某几位变反(与’1’异或 例1:把AX寄存器清零。例2:把DH的bit4,3变反 ① MOV AX,0 XOR DH. 18H ② XOR AX,AX ③ AND AX,O ④ SUB AX,AX
(4) 逻辑”异或” XOR
(5)测试指令TEST 操作与AND指令类似,但不将”与”的结果送回, 只影响标志位。 TEST指令常用于位测试,与条件转移指令一起 用 例:测试AL的内容是否为负数。 TEST AL,8OH;检查AL中D2=1? JNZ MINUS;是1(负数),转 MINUS 否则(正数)不转移 MINUS:∴
(5) 测试指令TEST
2.移位指令 (1)非循环移位指令 算术左移指令SAL( Shift arithmetic left 算术右移指令SAR( Shift arithmetic right) 逻辑左移指令SHL( Shift left 逻辑右移指令SHR( Shift right 这4条指令的格式相同,以SAL为例 SAL mem/reg,CL:移位位数大于1时 ,移位位数等于1时
2.移位指令 CL ;移位位数大于1时 1 ;移位位数等于1时
移位指令执行的操作如下图所示: 最高位 最低位 CF 0 (a)算术/逻辑左移SAL/SHL 最高位 最低位 最高位 最低位 CF CF 0 (b)算术右移SAR (c)逻辑右移SHR 非循环移位指令功能示意图
最高位 最低位 CF 0 (a)算术/逻辑左移 SAL/SHL 最高位 最低位 CF (b)算术右移 SAR 最高位 最低位 CF (c)逻辑右移 SHR 0 非循环移位指令功能示意图