条件设置字节指令(Set Byte Conditionally)是80386及其以后CPU所具有的一组指令。它们在测试条件方面与条件转移是一致的,但在功能方面,它们不是转移,而是根据测试条件的值来设置其字节操作数的内容为1或0。
条件设置字节指令的一般格式如下:
SETnn Reg/Mem ;80386+
其中:nn是表示测试条件的(见表5.4),操作数只能是8位寄存器或一个字节单元。
这组指令的执行不影响任何标志位。
表5.4 条件设置字节指令列表
|
指令的助忆符 |
操作数和检测条件之间的关系 |
|
SETZ/SETE |
Reg/Mem = ZF |
|
SETNZSETNE |
Reg/Mem = not ZF |
|
SETS |
Reg/Mem = SF |
|
SETNS |
Reg/Mem = not SF |
|
SETO |
Reg/Mem = OF |
|
SETNO |
Reg/Mem = not OF |
|
SETP/SETPE |
Reg/Mem = PF |
|
SETNP/SETPO |
Reg/Mem = not PF |
|
SETC/SETB/SETNAE |
Reg/Mem = CF |
|
SETNC/SETB/SETAE |
Reg/Mem = not CF |
|
SETNA/SETBE |
Reg/Mem = (CF or ZF) |
|
SETA/SETNBE |
Reg/Mem = not (CF or ZF) |
|
SETL/SETNGE |
Reg/Mem = (SF xor OF) |
|
SETNL/SETGE |
Reg/Mem = not (SF xor OF) |
|
SETLE/SETNG |
Reg/Mem = (SF xor OF) or ZF |
|
SETNLE/SETG |
Reg/Mem = not ((SF xor OF) or ZF) |
例5.19 编写程序段:检测寄存器EAX的8个16进制中有几个0H,并把统计结果存入BH中。
| 解: | |||
| 方法1:用条件转移指令来实现 | |||
| XOR | BH, BH | ||
| MOV | CX, 8 | ;测试寄存器EAX——8次 | |
| again: | TEST | AL, 0FH | ;测试低四位二进制是否为0H |
| JNZ | next | ||
| INC | BH | ||
| next: | ROR | EAX, 4 | ;循环向右移四位,为测试高四位作准备 |
| LOOP | again | ||
| 方法2:用条件设置字节指令来实现 | |||
| XOR | BH, BH | ||
| MOV | CX, 8 | ;测试寄存器EAX——8次 | |
| again: | TEST | AL, 0FH | ;测试低四位二进制是否为0H |
| SETZ | BL | ;如果AL的低四位是0,则BL置为1,否则,BL为0 | |
| ADD | BH, BL | ||
| ROR | EAX, 4 | ||
| LOOP | again | ||