3.3.3逻辑运算和移位指令 1.逻辑运算指令 ●运算规则:按位操作,无进/借位 ●对标志位的影响(除N0T指令外) CF OF SFZF PF AF 00***无定义 根据运算结果设置
1 3.3.3 逻辑运算和移位指令 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,01011111B
2 (1) 逻辑”与” AND 对两个操作数进行按位逻辑“与”操作。 格式:AND dest, src 用途:保留操作数的某几位,清零其他位。 例1:保留AL中低4位,高4位清0。 AND AL, 0FH 例2:AL中有字符’a’~’z’, 将其转换成大写。 AND AL, 01011111B
例3:测试AL的bt7,bt5,bt2是否都是1 AND AL,10100100B CMP AL,10100100B JZ YES if match, go to YES if not match YES: ; goes here if a“1
3 例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码变成相应十进制 数的ASCI码 OR AL 30H
4 对两个操作数进行按位逻辑”或”操作。 格式:OR dest, src 用途:对操作数的某几位置1;对两操作数 进行组合。 例1:把AL中的非压缩BCD码变成相应十进制 数的ASCII码。 OR AL, 30H (2) 逻辑”或” OR
例2:把AH和AL中的非压缩BCD码组合成压 缩的BCD码,放到AL中 MOV CL,4 SHL AH CL OR AL AH 例3:把AL的第5位置为1 oRAL,00100000B
5 例2:把AH和AL中的非压缩BCD码组合成压 缩的BCD码, 放到AL中。 MOV CL, 4 SHL AH, CL OR AL, AH 例3:把AL的第5位置为1 OR AL, 00100000B
(3)逻辑“非”(取反)NOT 对操作数进行按位逻辑”非”操作 格式: NoT mem/reg 例: NOT CX NOT BYTE PTR[DI
6 对操作数进行按位逻辑”非”操作。 格式:NOT mem/reg 例:NOT CX NOT BYTE PTR[DI] (3) 逻辑“非”(取反) NOT
(4)逻辑”异或”XOR 对两个操作数按位进行”异或”操作 格式: XOR dest,src 用途:对reg清零(自身异或) 把reg/mem的某几位变反(与1异或) 例1:把AX寄存器清零。例2:把DH的bit4,3变反 ① MOV AX,0 XOR d. 1 8H ② XOR AX,AX ③3 AND AX,0 ④ SUB AX,AX
7 对两个操作数按位进行”异或”操作。 格式:XOR dest, src 用途:对reg清零(自身异或) 把reg/mem的某几位变反(与’1’异或) 例1:把AX寄存器清零。 例2:把DH的bit4,3变反 ① MOV AX,0 XOR DH,18H ② XOR AX,AX ③ AND AX,0 ④ SUB AX,AX (4) 逻辑”异或” XOR
(5)测试指令TEST 操作与AN指令类似,但不将”与”的结果送回, 只影响标志位。 TEST指令常用于位测试,与条件转移指令一起 用 例:测试AL的内容是否为负数 TEST AL,8OH;检查AL中D7=1? JNZ MINUS;是1(负数),转 MINUS 否则(正数)不转移 MINUS ■■
8 操作与AND指令类似,但不将”与”的结果送回, 只影响标志位。 TEST指令常用于位测试,与条件转移指令一起 用。 例:测试AL的内容是否为负数。 TEST AL,80H ;检查AL中D7=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, 移位位数大于1时 ;移位位数等于1时
9 2.移位指令 (1)非循环移位指令 算术左移指令 SAL(Shift Arithmetic Left) 算术右移指令 SAR(Shift Arithmetic Right) 逻辑左移指令 SHL(Shift Left) 逻辑右移指令 SHR(Shift Right) 这4条指令的格式相同,以SAL为例: SAL mem/reg, CL ;移位位数大于1时 1 ;移位位数等于1时
移位指令执行的操作如下图所示: 最高位 最低位 CF 0 (a)算术/逻辑左移 SALSHL 最高位 最低位 最高位 最低位 CF CF (b)算术右移SAR (c)逻辑右移SHR 非循环移位指令功能示意图
10 移位指令执行的操作如下图所示: 最高位 最低位 CF 0 (a)算术/逻辑左移 SAL/SHL 最高位 最低位 CF (b)算术右移 SAR 最高位 最低位 CF (c)逻辑右移 SHR 0 非循环移位指令功能示意图