使用BIOS进行键盘输入【编程:字符串的输入】

使用BIOS进行键盘输入【编程:字符串的输入】

;=======字符串的输入=========
;功能:
; 1、在输入的同时显示这个字符串
; 2、在输入回车符后,字符串输入结束
; 3、能够删除已经输入的字符
;
;字符串的入栈、出栈、显示
;参数说明:
; 1、(ah)=功能号,
;   0表示入栈
;   1表示出栈
;   2表示显示
; 2、ds:si指向字符栈空间
; 3、 对于0号功能:(al)=入栈字符
;  对于1号功能:(al)=返回的字符
;  对于2号功能:(dh)、(dl)=字符串在屏幕上显示的行、列位置

assume cs:code, ds:stack

stack segment
 dd 128 dup(0)
stack ends

code segment
start:  
  mov ax, cs
  mov ds, ax
  mov si, 0
  mov dh, 12
  mov dl, 40
  call getstr

  mov ax, 4c00h
  int 21h

;=============================
;接收字符串输入控制
;=============================
getstr:
   push ax
   
getstrs:
   mov ah, 0  
   int 16h
   cmp al, 20h  ;al中存放的是扫描码对应的ASCII码
   jb nochar  ;ASCII码小于20h, 说明不是字符
   
   ;字符入栈
   mov ah, 0  ;ah: 0号功能 字符入栈  、 al:为入栈数据
   call charstack
   ;显示栈中的字符
   mov ah, 2
   call charstack
   jmp short getstrs
     
nochar:   
   cmp ah, 0eh  ;退格键的扫描码
   je backspace 
   cmp ah, 1ch  ;Enter键的扫描码
   je enter  
   jmp short getstrs  
   
;退格键
backspace:
   mov ah, 1
   call charstack ;字符出栈
   mov ah, 2
   call charstack ;显示栈中的字符
   jmp short getstrs

;Enter键  
enter:
   mov al, 0
   mov ah, 0  ;入栈0
   call charstack
   mov ah, 2
   call charstack ;显示栈中的字符
   
   pop ax
   ret
   
   
;==========================================================
;字符串的入栈、出栈、显示
;参数说明:
;1、(ah)=功能号,
;   0表示入栈
;   1表示出栈
;   2表示显示 
;2、ds:si指向字符栈空间
;3、对于0号功能:(al)=入栈字符
; 对于1号功能:(al)=返回的字符
; 对于2号功能:(dh)、(dl)=字符串在屏幕上显示的行、列位置
;==========================================================  
charstack: 
   jmp short charstart
 table dw charpush, charpop, charshow
 top  dw 0 ;保存栈顶  注意:始终指向栈顶有效字符的上一个

charstart:
   push bx
   push dx
   push di
   push si
   push es
   
   cmp ah, 2
   ja sret  ;ja高于则转移
   mov bl, ah
   mov bh, 0
   add bx, bx ;功能号*2 = 对应的功能子程序在地址表中的偏移
   jmp word ptr table[bx]
   

;字符入栈
charpush:
   mov bx, top  ;取得栈顶
   mov [si][bx], al
   inc top   ;栈顶+1
   jmp short sret
;字符出栈
charpop:
   cmp top, 0 ;检查栈是否为空
   je sret 
   dec top  ;栈顶-1  此时指向栈顶的有效字符
   mov bx, top
   mov al, [si][bx] ;把取出的字符保存在al中
   jmp short sret

;字符显示
charshow:
   mov bx, 0b800h
   mov es, bx
   mov al, 160
   mov ah, 0
   mul dh     ;ax=al*dh=160*行数
   mov di, ax
   add dl, dl  ;dl+dl = 偏移量
   mov dh, 0
   add di, dx  ;di=(160*行数)+2*列数
   
   mov bx, 0
 charshows:
   cmp bx, top  ;bx为 存放数据空间的偏移
   jne noempty  ;栈不为空 显示
   mov byte ptr es:[di], ' ' 
   jmp short sret 
   
 noempty:
   mov al, [si][bx]
   mov es:[di], al
   mov byte ptr es:[di+2], ' ' ;如果是删除 就可以把删除的字符清空
   inc bx
   add di, 2
   jmp short charshows
;结束
sret:
   pop es
   pop si
   pop di
   pop dx
   pop bx
   ret
      
code ends
end start

 

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/110224.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • Yii框架官方教程增补篇6——基础知识:应用、组件、配置、生命周期

    Yii框架官方教程增补篇6——基础知识:应用、组件、配置、生命周期

    2021年8月28日
    68
  • 基于流水线的CPU的设计「建议收藏」

    基于流水线的CPU的设计「建议收藏」1.我们知道,CPU是电脑的中央处理单元,CPU到底是怎么连续的执行指令的。我们以MIPS为例,探究一下。2.基础的知识我们需要知道,CPU执行一条指令时分为五个阶段的:(1)在内存取指令(2)根据指令读寄存器(3)利用寄存器中的数据ALU(4)访问内存(5)写寄存器。一般是这五个阶段,但是很多指令并不是说这五个阶段全部都在做事情。比如add,它只有四个阶段,其中不涉及到内存的访问。但是,又有…

    2022年8月14日
    5
  • server宕机监控、检測、报警程序(139绑定手机短信报警)monitor_down.sh

    server宕机监控、检測、报警程序(139绑定手机短信报警)monitor_down.sh

    2021年12月4日
    44
  • 第二代身份证 验证

    第二代身份证 验证
    今天,在盛大某网站注册的时候,身份证必填,但我又不想填真实身份证号码,于是随便编了串自认为合法的身份证号码,但是却马上被提示号码错误,由于响应速度极快,可以肯定不是联机校验正确性的,那也就是说第二代身份证除了大家都知道的几位表示生日和性别的规则以外,还有另外的自我校验规则。于是翻开页面源码查看,发现这段js没有被压缩,所以规则也很好懂。
    就在这里给大家科普下,不知道是不是火星了,呵呵。
    以下代码来自这里,版权归盛大。当然,你也可以在维基百科找到更详细的介绍和算法。

    2022年6月27日
    28
  • java绘图板

    java绘图板

    2021年12月7日
    34
  • Maven 菜鸟教程 2 项目目录结构

    Maven 菜鸟教程 2 项目目录结构目录结构说明src/main/javaapplicationlibrarysources-java源代码文件,会自动编译到classes文件夹下src/main/resourcesapplicationlibraryresources-资源库,会自动编译到classes文件夹下src/main/filtersresources

    2025年9月16日
    5

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号