汇编语言之AL字节内容反向排序
基础知识
- SHL为逻辑左移命令,其中OPR为寄存器或者内存单元,移位次数可以是1或者CL寄存器,如需移位的次数大于1,则可以在该移位指令前把移位次数先送CL寄存器中。
- 当执行逻辑或算数左移时,操作结果相同,均是最低位补0,移出的最高位送CF标志位。执行逻辑右移时,最高位补0,移出的最低位送CF标志位;当执行算数右移时,OPR被认为是有符号数,则最高位补符号位自身。
实验内容
AL字节内容方向排序
程序设计思路
所谓反向排序,指的是将其二进制位反向。如AL中为1010 0000,反向排序后的结果为0000 1010;再比方说,AL为1000 0000,反向排序后的内容为 0000 0001。
首先初始化AL和DL为0,并且初始化AL中的内容为要反向排序的内容。采用LOOP执行循环,所以需要初始化CX为循环次数8,同时设置基数变量BL为1。
然后使用SHL对AL进行操作,接着判断CF标志位,若CF标志位为1,则将BL加至DL,同时将BL左移一位(相当于BL乘2),如此循环8次。DL即为所求。
程序代码
CODES SEGMENT
ASSUME CS:CODES
START:
;AL->JCF
;IF CF=0 RCL
MOV AX,0000
MOV AL,0D0H
;INIT
MOV DL,00H
MOV BL,00H
MOV BL,1
MOV CX,8
DOIT:
SHL AL,1
JNC PASS
ADD DL,BL
PASS:
SHL BL,1
LOOPNE DOIT
;END
MOV AH,4CH
INT 21H
CODES ENDS
END START