使用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)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • mysql 修改字段类型并设置默认值[通俗易懂]

    mysql 修改字段类型并设置默认值[通俗易懂]/*修改表obj_Device,把字段类型channelNum改为TINYINT(3),默认值为8*/altertable obj_DevicechangecolumnchannelNumchannelNumTINYINT(3)NOTNULLDEFAULT8;

    2022年5月1日
    178
  • 关于数据库tinyint 字段的值范围「建议收藏」

    关于数据库tinyint 字段的值范围「建议收藏」tinyint从-2^7(-128)到2^7-1(123)的整型数据。存储大小为1个字节。unsigned是从0到255的整型数据。所以建表的时候只能是tinyint(3),哪怕你建tinyint(100),他最大还是3位这么多。转载于:https://www.cnblogs.com/jinhaidong/p/5944554.html…

    2025年11月19日
    4
  • Python字符串中删除特定字符的方法

    Python字符串中删除特定字符的方法这篇文章主要介绍了Python字符串中删除特定字符的方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧分析在Python中,字符串是不可变的。所以无法直接删除字符串之间的特定字符。所以想对字符串中字符进行操作的时候,需要将字符串转变为列表,列表是可变的,这样就可以实现对字符串中特定字符的操作。1、删除特定字符特定字符…

    2022年6月10日
    74
  • 冒泡排序算法,C语言冒泡排序算法详解

    冒泡排序算法,C语言冒泡排序算法详解冒泡排序是最简单的排序方法,理解起来容易。虽然它的计算步骤比较多,不是最快的,但它是最基本的,初学者一定要掌握。冒泡排序的原理是:从左到右,相邻元素进行比较。每次比较一轮,就会找到序列中最大的一个或最小的一个。这个数就会从序列的最右边冒出来。以从小到大排序为例,第一轮比较后,所有数中最大的那个数就会浮到最右边;第二轮比较后,所有数中第二大的那个数就会浮到倒数第二个位置……就这样一轮一轮地比较,最后实现从小到大排序。比如对下面这个序列进行从小到大排序:9021132-5834第一轮:

    2022年6月25日
    24
  • pycharm2021linux 激活码【在线注册码/序列号/破解码】

    pycharm2021linux 激活码【在线注册码/序列号/破解码】,https://javaforall.net/100143.html。详细ieda激活码不妨到全栈程序员必看教程网一起来了解一下吧!

    2022年3月20日
    76
  • linux udp编程 绑定失败_udp socket编程

    linux udp编程 绑定失败_udp socket编程简介UDP协议与TCP协议一样用于处理数据包,在OSI模型中,两者都位于传输层,处于IP协议的上一层。UDP有不提供数据包分组、组装和不能对数据包进行排序的缺点,也就是说,当报文发送之后,是无法得知其是否安全完整到达的。代码实现#ifndef_SOCKET_HPP_#define_SOCKET_HPP_#include<iostream>#include<sstream>#include<exception>#include<strin

    2025年10月2日
    4

发表回复

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

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