用汇编语言实现从1加到100(1+2+...+100)

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

;课堂作业
;计算1+2+...+100
DATA SEGMENT
  COUNT DW 0    ;计数
DATA ENDS   

STACK SEGMENT PARA  STACK
  BUF DW 20H DUP (0)
  LEN EQU $-BUF
STACK ENDS

CODESEG SEGMENT
ASSUME CS:CODESEG,SS:STACK,DS:DATA
START:
;初始化堆栈段ss和数据段ds
  MOV AX,STACK
  MOV SS,AX
  MOV SP,LEN
  MOV AX,DATA
  MOV DS,AX
  
  MOV CX,64H ;循环100次
  MOV AX,0
S:
    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 AX
RET

;输出AL的数字和字母
DISP_1_HEX:  
  PUSH AX
  PUSH DX
  PUSHF
  MOV DL,AL
  CMP DL,09
  JBE L_1  ;小于等于9则跳过下一条语句
  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 DX
RET

CODESEG ENDS
END START

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

猜你喜欢

转载自www.cnblogs.com/jdemarryme/p/9071575.html