3.3.3逻辑运算和移位指令 1.逻辑运算指令 运算规则:按位操作,无进/借位 ●对标志位的影响(除N0T指令外): CF OF SF ZF PF AF 00***无定义 根据运算结果设置
1.逻辑运算指令 ● 运算规则:按位操作,无进/借位 ● 对标志位的影响(除NOT指令外): CF OF SF ZF PF AF 0 0 * * * 无定义 根据运算结果设置
(1)逻辑”与”AND 对两个操作数进行按位逻辑“与”操作 格式: and dest,src 用途:保留操作数的某几位,清零其他位。 例1:保留AL中低4位,高4位清0。 AND AL OFH 例2:AL中有字符'a'~’z,将其转换成大写。 AND AL,010111118
(1) 逻辑”与” AND 对两个操作数进行按位逻辑“与”操作。 格式:AND dest, src 用途:保留操作数的某几位,清零其他位。 例1:保留AL中低4位,高4位清0。 AND AL, 0FH 例2:AL中有字符’a’~’z’ , 将其转换成大写
例3:测试AL的b7,b5,b2是否都是1。 AND AL,10100100B CMP AL,10100100B JZ YES if match, go to YES if not match YES: ; goes here if a“1
例3:测试AL的bit7,bit5,bit2是否都是1。 AND AL, 10100100B CMP AL, 10100100B JZ YES ; if match, go to YES … … ; if not match YES: … … ; goes here if all ‘1’
(2)逻辑”或” OR 对两个操作数进行按位逻辑”或”操作。 格式: or dest,src 用途:对操作数的某几位置1;对两操作数 进行组合。 例1:把A中的非压缩BCD码变成相应十进制 数的 ASCII码 OR AL. 30H
格式:OR dest, src 用途:对操作数的某几位置1;对两操作数 进行组合。 (2) 逻辑”或” OR
例2:把AH和AL中的非压缩BCD码组合成压 缩的BCD码,放到AL中。 MOV CL4 SHL AH. CL OR AL. AH 例3:把AL的第5位置为1 oRAL,00100000B
例2: 例3:把AL的第5位置为1 OR AL, 00100000B
(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 非循环移位指令功能示意图