Intel8086处理器使用NASM汇编语言实现操作系统05-以大写16进制在屏幕显示内存中的值(shr/shl/jb)

本文主要是介绍Intel8086处理器使用NASM汇编语言实现操作系统05-以大写16进制在屏幕显示内存中的值(shr/shl/jb),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

本文将内存中的1个值以16进制的方式显示到屏幕上,例如:
内存中的值是:0xAB,那么屏幕上就显示两个字母,A和B
内存中的值是:0xB8,那么屏幕上就显示两个字母,B和8
具体的做法是这样的:一个字节由2个16进制字符表示,所以要将1个字节分割成高4位和低4位,然后再分别判断高4位是0-9还是A-F,如果是0-9,则它的ASCII是该值加上48D,如果是A-F,则它的ASCII是该值加上55D,例如,值是0x8,则它的ASCII是8+48D=56D,如果值是0xB,则它的ASCII是11+55D=66D,低4位同样使用该方式判断,这样,最终就将一个字节以16进制的方式显示到屏幕上了

在这之前,要先介绍两个新的汇编指令shr,jb
shr正确写法

mov al,11110000B
shr al,4			;al的值是00001111B
mov al,11110000B
shr al,3			;al的值是00011110B
mov al,11110011B
shr al,1			;al的值是01111001B

shl正确写法

mov al,00110000B
shl al,1			;al的值是01100000B

**jb(Jump Below)**正确写法(小于则跳转)

aa:
mov ax,8
cmp ax,9			
jb	aa				;如果ax里的值小于9,则跳转到标号aa处

下面的示例是将内存中的数据0xD8,以字符D8显示到屏幕上

mov ax,0xb800		;设置显存段地址,如果不设置,直接写[五位数地址],会越界的
mov ds,ax			
mov al,0xD8			;要显示的内容
mov bl,al
and bl,11110000B	;取AL高4位,放到BL中,本例中是D,一会要在屏幕上显示'D'
shr bl,4			;将BL的高4位,放到BL的低4位中,目的是一会转换ascii的时候;要加48D或55D,如果在高4位,并且是1111B,直接BL就溢出了
cmp bl,1010B		;用BL低四位和10D比较,如果小于,则在屏幕上显示数字,如果;大于等于,则在屏幕上显示A-F
jb  showNumber1		;显示数字的功能
jmp showCapital1	;显示字母的功能(如果是显示数字,则该标号会被跳过去)
show1:
mov bl,al           ;取AL低4位,放到BL中,本例中是8,一会要在屏幕上显示'8'
and bl,1111B
cmp bl,1010B
jb  showNumber2
jmp showCapital2
show2: jmp show2showNumber1:		add bl,48D			;此时bl就是asicc
mov byte [0x00],bl
mov byte [0x01],0x0b
jmp show1
showCapital1:		
add bl,55D			;此时bx就是asicc
mov byte [0x00],bl
mov byte [0x01],0x0b
jmp show1showNumber2:		
add bl,48D			;此时bx就是asicc
mov byte [0x02],bl
mov byte [0x03],0x0b
jmp show2
showCapital2:		
add bl,55D			;此时bx就是asicc
mov byte [0x02],bl
mov byte [0x03],0x0b
jmp show2
times 510-($-$$) db 0
dw 0Xaa55

这篇关于Intel8086处理器使用NASM汇编语言实现操作系统05-以大写16进制在屏幕显示内存中的值(shr/shl/jb)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1057310

相关文章

MySQL 内存使用率常用分析语句

《MySQL内存使用率常用分析语句》用户整理了MySQL内存占用过高的分析方法,涵盖操作系统层确认及数据库层bufferpool、内存模块差值、线程状态、performance_schema性能数据... 目录一、 OS层二、 DB层1. 全局情况2. 内存占js用详情最近连续遇到mysql内存占用过高导致

Android Paging 分页加载库使用实践

《AndroidPaging分页加载库使用实践》AndroidPaging库是Jetpack组件的一部分,它提供了一套完整的解决方案来处理大型数据集的分页加载,本文将深入探讨Paging库... 目录前言一、Paging 库概述二、Paging 3 核心组件1. PagingSource2. Pager3.

python设置环境变量路径实现过程

《python设置环境变量路径实现过程》本文介绍设置Python路径的多种方法:临时设置(Windows用`set`,Linux/macOS用`export`)、永久设置(系统属性或shell配置文件... 目录设置python路径的方法临时设置环境变量(适用于当前会话)永久设置环境变量(Windows系统

python使用try函数详解

《python使用try函数详解》Pythontry语句用于异常处理,支持捕获特定/多种异常、else/final子句确保资源释放,结合with语句自动清理,可自定义异常及嵌套结构,灵活应对错误场景... 目录try 函数的基本语法捕获特定异常捕获多个异常使用 else 子句使用 finally 子句捕获所

C++11右值引用与Lambda表达式的使用

《C++11右值引用与Lambda表达式的使用》C++11引入右值引用,实现移动语义提升性能,支持资源转移与完美转发;同时引入Lambda表达式,简化匿名函数定义,通过捕获列表和参数列表灵活处理变量... 目录C++11新特性右值引用和移动语义左值 / 右值常见的左值和右值移动语义移动构造函数移动复制运算符

最新Spring Security的基于内存用户认证方式

《最新SpringSecurity的基于内存用户认证方式》本文讲解SpringSecurity内存认证配置,适用于开发、测试等场景,通过代码创建用户及权限管理,支持密码加密,虽简单但不持久化,生产环... 目录1. 前言2. 因何选择内存认证?3. 基础配置实战❶ 创建Spring Security配置文件

Python对接支付宝支付之使用AliPay实现的详细操作指南

《Python对接支付宝支付之使用AliPay实现的详细操作指南》支付宝没有提供PythonSDK,但是强大的github就有提供python-alipay-sdk,封装里很多复杂操作,使用这个我们就... 目录一、引言二、准备工作2.1 支付宝开放平台入驻与应用创建2.2 密钥生成与配置2.3 安装ali

Spring Security 单点登录与自动登录机制的实现原理

《SpringSecurity单点登录与自动登录机制的实现原理》本文探讨SpringSecurity实现单点登录(SSO)与自动登录机制,涵盖JWT跨系统认证、RememberMe持久化Token... 目录一、核心概念解析1.1 单点登录(SSO)1.2 自动登录(Remember Me)二、代码分析三、

C#中lock关键字的使用小结

《C#中lock关键字的使用小结》在C#中,lock关键字用于确保当一个线程位于给定实例的代码块中时,其他线程无法访问同一实例的该代码块,下面就来介绍一下lock关键字的使用... 目录使用方式工作原理注意事项示例代码为什么不能lock值类型在C#中,lock关键字用于确保当一个线程位于给定实例的代码块中时

MySQL 强制使用特定索引的操作

《MySQL强制使用特定索引的操作》MySQL可通过FORCEINDEX、USEINDEX等语法强制查询使用特定索引,但优化器可能不采纳,需结合EXPLAIN分析执行计划,避免性能下降,注意版本差异... 目录1. 使用FORCE INDEX语法2. 使用USE INDEX语法3. 使用IGNORE IND