条件设置字节指令(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 | ||