(十)《汇编语言(王爽)》 | 实验 6:实践课程中的程序

2024-01-05 18:08

本文主要是介绍(十)《汇编语言(王爽)》 | 实验 6:实践课程中的程序,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1. 预备知识

  • 目前为止还没有涉及到判断语句的使用,可通过大小写字符的二进制形式来进行大小写转换:
A 41 0100 0001    B 42 0100 0010    C 43 0100 0011  ...
a 61 0110 0001    b 62 0110 0010    c 63 0110 0011  ...

可观察到,对应大小写字符仅有第 5 位不同,所以可通过汇编指令按位与指令 and 和按位或指令 or 完成字符的大小写转换。如将字符转换为大写字符:and 1101 1111,将字符转换为小写字符:or 0010 0000。

  • SI 和 DI 是 8086CPU 中和 BX 功能相近的寄存器,但 SI 和 DI 不能分为两个 8 位寄存器
  • 根据不同场景使用不同寻址方式:
  • [idata] 用一个常量表示地址,可用于直接定位一个内存单元
  • [bx] 用一个变量表示地址,可用于间接定位一个内存单元
  • [bx+idata] 用一个常量和变量表示地址,可在一个起始地址的基础上用变量间接定位一个内存单元
  • [bx+si] 用两个变量表示地址
  • [bx+si+idata] 用两个变量和一个常量表示地址
  • 前面提到,寄存器 CX 用以配置 loop 指令实现循环,如果涉及到多重循环,则内层循环的 CX 值会影响外层循环的值,解决办法是使用栈来暂存数据

2. 实验任务

(1)将 datasg 段中每个单词的头一个字母改为大写字母。

assume cs:codesg,ds:datasg
datasg segmentdb '1. file         'db '2. edit         'db '3. search       'db '4. view         'db '5. options      'db '6. help         '
datasg ends
codesg segment
start:?		;待完成部分
codesg ends
end start

在定义数据段时,字符串后半部分使用空格填充至 16 字节,其在内存中的存放形式为:

在这里插入图片描述
可以看到,每个单词的第一个字母的相对位置都相同,即第 3 列。所以,可以使用一重循环完成,循环每次索引上二维数组的行,然后每次定位到行的第 3 列即可索引到相应字母,最后使用逻辑与运算将字符转换为大写字母。

	mov ax,datasgmov ds,ax			;使用段寄存器DS指向数据段datasgmov bx,0			mov cx,6			;循环次数
s:	mov al,[bx+3]		;将相对于BX偏移3个位置的字符送入寄存器AL中and al,11011111b	;通过逻辑与运算将字母转换为大写字母mov [bx+3],al		;将转换后的字符重写回对应的内存单元add bx,16			;BX每次偏移16个位置loop smov ax,4c00hint 21h

使用指令 g 跳到循环执行前,此时寄存器 DS 为字符串存放内存的段地址:

请添加图片描述

以 076A:0000~076A:000F 为例,里面存放了第一个字符串的内容,21、2E、20、66、69、6C、65 分别为字符 1. file 的 ASCII 码值,后面连续的 20 为填充的空格。待改变部分的偏移地址为 3,即 66、65、73、76、6F 和 68。程序执行结束后再查看这段内存单元:

请添加图片描述

(2)将 datasg 段中每个单词的字母改为大写字母。

assume cs:codesg,ds:datasg
datasg segmentdb 'ibm             'db 'dec             'db 'dos             'db 'vax             '
datasg ends
codesg segment
start:?		;待完成部分
codesg ends
end start

在定义数据段时,字符串后半部分使用空格填充至 16 字节,其在内存中的存放形式为:

在这里插入图片描述
和上一题只改变一个字母不同,本题要求同时改变三个字母,所以使用双重循环完成。同样地,外层循环用于索引每个字符串,内层循环遍历字符串中的每个字符。注意,上面提到多重循环需要注意循环控制量 CX 的存取,这里使用栈

stacksg segment			;额外定义栈段用于存取寄存器CX的值dw 0,0,0,0,0,0,0,0
stacksg endsmov ax,stacksgmov ss,axmov sp,16		;定义空栈mov ax,datasgmov ds,axmov bx,0		;使用段寄存器DS指向数据段datasgmov cx,4		;外层循环次数
s1:	push cx	;使用栈保存CX的值mov si,0		;内层循环的偏移mov cx,3		;内层循环次数
s2:	mov al,[bx+si]	;内层循环完成将字母转换为大写字母and al,11011111bmov [bx+si],alinc si			;内层每次偏移1个字节loop s2add bx,16		;外层循环每次偏移16个字节pop cx			;恢复CX的值loop s1mov ax,4c00hint 21h

(3)将 datasg 段中每个单词的前四个字母改为大写字母。

assume cs:codesg,ds:datasg
datasg segmentdb '1. display      'db '2. brows        'db '3. replace      'db '4. modify       '
datasg ends
codesg segment
start:?		;待完成部分
codesg ends
end start

在定义数据段时,字符串后半部分使用空格填充至 16 字节,其在内存中的存放形式为:

在这里插入图片描述

本题和上一题思路类似,外层循环功能完全一致,内存循环也是实现功能将固定数量的字母转换为大写。在上一题中,每行待改变字母的起始偏移为 0,本题为 3;所以,上一题使用 [bx+si] 来定位起始字母,本题使用 [bx+si+3] 来定位起始字母。

stacksg segment			;额外定义栈段用于存取寄存器CX的值dw 0,0,0,0,0,0,0,0
stacksg endsmov ax,stacksgmov ss,axmov sp,16		;定义空栈mov ax,datasgmov ds,axmov bx,0			;使用段寄存器DS指向数据段datasgmov cx,4			;外层循环次数
s1:	push cx				;使用栈保存CX的值mov si,0			;内层循环的偏移mov cx,4			;内层循环次数
s2:	mov al,[bx+si+3]	;内层循环完成将字母转换为大写字母and al,11011111bmov [bx+si+3],alinc si				;内层每次偏移1个字节loop s2add ax,16			;外层循环每次偏移16个字节pop cx				;恢复CX的值loop s1mov ax,4c00hint 21h

如果需要将前 5 个字母转换为大写,则 8 位寄存器 AL 的存储空间不足。

这篇关于(十)《汇编语言(王爽)》 | 实验 6:实践课程中的程序的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

MySQL 用户创建与授权最佳实践

《MySQL用户创建与授权最佳实践》在MySQL中,用户管理和权限控制是数据库安全的重要组成部分,下面详细介绍如何在MySQL中创建用户并授予适当的权限,感兴趣的朋友跟随小编一起看看吧... 目录mysql 用户创建与授权详解一、MySQL用户管理基础1. 用户账户组成2. 查看现有用户二、创建用户1. 基

Spring Boot 实现 IP 限流的原理、实践与利弊解析

《SpringBoot实现IP限流的原理、实践与利弊解析》在SpringBoot中实现IP限流是一种简单而有效的方式来保障系统的稳定性和可用性,本文给大家介绍SpringBoot实现IP限... 目录一、引言二、IP 限流原理2.1 令牌桶算法2.2 漏桶算法三、使用场景3.1 防止恶意攻击3.2 控制资源

springboot项目中整合高德地图的实践

《springboot项目中整合高德地图的实践》:本文主要介绍springboot项目中整合高德地图的实践,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一:高德开放平台的使用二:创建数据库(我是用的是mysql)三:Springboot所需的依赖(根据你的需求再

SpringBoot3应用中集成和使用Spring Retry的实践记录

《SpringBoot3应用中集成和使用SpringRetry的实践记录》SpringRetry为SpringBoot3提供重试机制,支持注解和编程式两种方式,可配置重试策略与监听器,适用于临时性故... 目录1. 简介2. 环境准备3. 使用方式3.1 注解方式 基础使用自定义重试策略失败恢复机制注意事项

MySQL MCP 服务器安装配置最佳实践

《MySQLMCP服务器安装配置最佳实践》本文介绍MySQLMCP服务器的安装配置方法,本文结合实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下... 目录mysql MCP 服务器安装配置指南简介功能特点安装方法数据库配置使用MCP Inspector进行调试开发指

SQLite3命令行工具最佳实践指南

《SQLite3命令行工具最佳实践指南》SQLite3是轻量级嵌入式数据库,无需服务器支持,具备ACID事务与跨平台特性,适用于小型项目和学习,sqlite3.exe作为命令行工具,支持SQL执行、数... 目录1. SQLite3简介和特点2. sqlite3.exe使用概述2.1 sqlite3.exe

SQL中JOIN操作的条件使用总结与实践

《SQL中JOIN操作的条件使用总结与实践》在SQL查询中,JOIN操作是多表关联的核心工具,本文将从原理,场景和最佳实践三个方面总结JOIN条件的使用规则,希望可以帮助开发者精准控制查询逻辑... 目录一、ON与WHERE的本质区别二、场景化条件使用规则三、最佳实践建议1.优先使用ON条件2.WHERE用

Springboot整合Redis主从实践

《Springboot整合Redis主从实践》:本文主要介绍Springboot整合Redis主从的实例,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录前言原配置现配置测试LettuceConnectionFactory.setShareNativeConnect

python编写朋克风格的天气查询程序

《python编写朋克风格的天气查询程序》这篇文章主要为大家详细介绍了一个基于Python的桌面应用程序,使用了tkinter库来创建图形用户界面并通过requests库调用Open-MeteoAPI... 目录工具介绍工具使用说明python脚本内容如何运行脚本工具介绍这个天气查询工具是一个基于 Pyt

Ubuntu设置程序开机自启动的操作步骤

《Ubuntu设置程序开机自启动的操作步骤》在部署程序到边缘端时,我们总希望可以通电即启动我们写好的程序,本篇博客用以记录如何在ubuntu开机执行某条命令或者某个可执行程序,需要的朋友可以参考下... 目录1、概述2、图形界面设置3、设置为Systemd服务1、概述测试环境:Ubuntu22.04 带图