数据的直接定址表(1603)

简介: 本文为《汇编语言程序设计》1603小节例程。点击链接…进课程主页。问题:以十六进制的形式在屏幕中间显示给定的byte 型数据。

本文为《汇编语言程序设计》1603小节例程。点击链接…进课程主页。

问题:以十六进制的形式在屏幕中间显示给定的byte 型数据。
分析:先将一个byte的高4位和低4 位分开,显示对应的数码字符

最简解决方案:最简方案:建立一张表,表中依次存储字符’0’~’F’,通过数值0~15直接查找到对应的字符。
程序:

assume cs:code
code segment
start:  mov al,12h
        call showbyte
        mov ax,4c00h
        int 21h

;子程序:
;用al传送要显示的数据
showbyte:
        jmp short show
        table db '0123456789ABCDEF' ;字符表
show:   push bx
        push es
    push cx
        mov ah,al
    mov cl,4
        shr ah,cl   ;右移4位,ah中得到高4位的值
        and al,00001111b        ;al中为低4位的值

        mov bl,ah
        mov bh,0
        mov ah,table[bx]        ;用高4位的值作为相对于table的偏移,取得对应的字符

        mov bx,0b800h
        mov es,bx
        mov es:[160*12+40*2],ah

        mov bl,al
        mov bh,0
        mov al,table[bx]        ;用低4位的值作为相对于table的偏移,取得对应的字符

        mov es:[160*12+40*2+2],al

        pop cx
        pop es
        pop bx
        ret

code ends
end start

应用示例:为加快运算速度而采用查表方法
问题:编写程序,计算sin(x),x∈{0°,30°,60°,90°,120°,150°,180°},并在屏幕中间显示计算结果。
空间换时间方案:将所要计算的sin(x) 的结果都存储到一张表中,然后用角度值来查表,找到对应的sin(x)的值。
具体方法:(1)用ax向子程序传递角度;(2)以 角度值/30 为table 表

目录
相关文章
|
7月前
|
搜索推荐
舒尔特表练习记
舒尔特表练习记 1 练习的开始
66 0
|
7月前
|
SQL 前端开发 关系型数据库
MYSQL基础之【创建数据表,删除数据表】
MYSQL基础之【创建数据表,删除数据表】
65 0
|
Oracle 关系型数据库 MySQL
根据一张表更新另一张表
根据一张表更新另一张表
|
消息中间件 安全 Dubbo
程序员健康作息表
程序员健康作息表
|
存储 索引
各种表
符号表 opcode代码中的操作数都是一个符号表中的索引, 在符号表中存储的是字符串, 方法名, 变量名, 变量值, 让虚拟机通过索引在符号表中获取真正的参数 字母表 在我们定义的脚本语言风格中用到的所有不可以再分的符号放到字母表中, 通过字母表中的单个字符组合出各式各样的单词
751 0
|
存储 数据库 索引
快速删除数据库中所有表中的数据
原文:快速删除数据库中所有表中的数据 select 'truncate table ' + Name + ';' from sysobjects where xtype='U' order by name asc; 该条语句执行之后会将数据库中所有的表都查询出来,复制出来之后执行truncate语句即可 sysobjects 在数据库内创建的每个对象(约束、默认值、日志、规则、存储过程等)在表中占一行。
1700 0
|
关系型数据库 PostgreSQL API
下一篇
DataWorks