欢迎光临
我们一直在努力

汇编语言实现延时,机器语言汇编是怎么实现的

用汇编语言实现1+2+…+100

;课堂作业;计算1+2+…+100DATA SEGMENT COUNT DW 0 ;计数DATA ENDS STACK SEGMENT PARA STACK BUF DW 20H DUP (0) LEN EQU $-BUFSTACK ENDSCODESEG SEGMENTASSUME CS:CODESEG,SS:STACK,DS:DATASTART:;初始化堆栈段ss和数据段ds MOV AX,STACK MOV SS,AX MOV SP,LEN MOV AX,DATA MOV DS,AX MOV CX,64H ;循环100次 MOV AX,0S: ADD COUNT,01H ADD AX,COUNT LOOP S MOV DL,AL MOV AL,AH CALL DISP_2_HEX MOV AL,DL CALL DISP_2_HEX CALL DISP_CREF MOV AH,4CH INT 21H ;将AL的高四位与低四位分别输出DISP_2_HEX: PUSH AX PUSH BX PUSHF MOV AH,0 ;清零 MOV BL,10H ;作除法 DIV BL ;AL :商 高位 AH 余数 低位 CALL DISP_1_HEX ;输出AL的结果 MOV AL,AH CALL DISP_1_HEX POPF POP BX POP AXRET;输出AL的数字和字母DISP_1_HEX: PUSH AX PUSH DX PUSHF MOV DL,AL CMP DL,09 JBE L_1 ;小于等于9则跳过下一条语句 便宜美国vps ADD DL,27H ;大于10则转换为小写字母并执行到下面的L_1的RET结束 ;数字10与字符a差为39(27H);数字输出(1的ascii码为31H)L_1: ADD DL,30H ;数字转换为字符 MOV AH,02H INT 21H POPF POP DX POP AX RET;输出回车换行DISP_CREF: PUSH DX PUSH AX MOV AH,02H MOV DL,0DH INT 21H MOV DL,0AH INT 21H POP AX POP DXRETCODESEG ENDSEND START

?

输出结果为13ba(5050的十六进制)

?

转载于:https://www.cnblogs.com/jdemarryme/p/9071575.html

17718427

赞(0)
【声明】:本博客不参与任何交易,也非中介,仅记录个人感兴趣的主机测评结果和优惠活动,内容均不作直接、间接、法定、约定的保证。访问本博客请务必遵守有关互联网的相关法律、规定与规则。一旦您访问本博客,即表示您已经知晓并接受了此声明通告。