条件设置字节指令(Set Byte Conditionally)是80386及其以后
cpu所具有的一组指令。它们在测试条件方面与条件转移是一致的,但在功能方面,它们不是转移,而是根据测试条件的值来设置其字节操作数的内容为1或0。
条件设置字节指令的一般格式如下:
SETnn Reg/Mem ;80386+
其中:nn是表示测试条件的(见表5.4),操作数只能是8位寄存器或一个字节单元。
这组指令的执行不影响任何标志位。
表5.4 条件设置字节指令列表
指令的助忆符操作数和检测条件之间的关系
SETZ/SETEReg/Mem = ZF
SETNZSETNEReg/Mem = not ZF
SETSReg/Mem = SF
SETNSReg/Mem = not SF
SETOReg/Mem = OF
SETNOReg/Mem = not OF
SETP/SETPEReg/Mem = PF
SETNP/SETPOReg/Mem = not PF
SETC/SETB/SETNAEReg/Mem = CF
SETNC/SETB/SETAEReg/Mem = not CF
SETNA/SETBEReg/Mem = (CF or ZF)
SETA/SETNBEReg/Mem = not (CF or ZF)
SETL/SETNGEReg/Mem = (SF xor OF)
SETNL/SETGEReg/Mem = not (SF xor OF)
SETLE/SETNGReg/Mem = (SF xor OF) or ZF
SETNLE/SETGReg/Mem = not ((SF xor OF) or ZF)
例5.19 编写程序段:检测寄存器EAX的8个16进制中有几个0H,并把统计结果存入BH中。
解:
方法1:用条件转移指令来实现
XORBH, BH
MOVCX, 8;测试寄存器EAX――8次
again:TESTAL, 0FH;测试低四位二进制是否为0H
JNZnext
INCBH
next:ROREAX, 4;循环向右移四位,为测试高四位作准备
LOOPagain
方法2:用条件设置字节指令来实现
XORBH, BH
MOVCX, 8;测试寄存器EAX――8次
again:TESTAL, 0FH;测试低四位二进制是否为0H
SETZBL;如果AL的低四位是0,则BL置为1,否则,BL为0
ADDBH, BL
ROREAX, 4
LOOPagain