汇编语言学习第七章-更灵活的定位内存地址的方法

2024-08-25 05:18

本文主要是介绍汇编语言学习第七章-更灵活的定位内存地址的方法,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

            本博文系列参考自<<汇编语言>>第三版,作者:王爽


前面已经通过类似[0]和[bx]的方法进行了内存定位了。本章将涉及更多内存地址定位和编程的方法。


7.1 and 和 or 指令

(1) and指令,逻辑按位与指令

例如:

mov al,01100011B

and al,00111011B

执行后 al=00100011B 

and指令可以用来将某个数的位置为零。

比如我们要将al的第二位置为零,则: and al,11111101B

依次类推。


(2) or指令,逻辑按位或指令

例如:

mov al,01100011B

or   al,00111011B

执行后 al=01111011B

or指令可以用来将某个数的位置为1

比如我们要将al的第高位置为一,则: or al,10000000B


7.2 关于ASCII码

在计算机中所有的信息都是以二进制方式进行存储的,那么计算机是如何存储我们输入的文本,字符这些信息,然后再讲这些信息输出给用户呈现呢?

那么我们可以这样想,当我们输入到计算机的信息和输出展示给用户的信息都是通过某种规则进行转换的。输入的时候通过这样的规则将用户的信息转换为二进制存储,输出的时候将计算机中存储的二进制信息进行翻译出来给用户。那么不言而喻,要想输入的信息和输出信息表达的意思是一致的,我们必须采用某种同样的规则来对这些信息进行解释。这就称为编码。

计算机中最常用的编码方式为ASCII编码。该编码用7位二进制表示128个基本的字符,字母和数字。后来ASCII扩展到8位增加了128个编码。当然根据每个国家文字的不同,又有很多不同编码比如中国的GB2312,不过为了进一步统一编码规则,现在也逐步推广unicode编码的使用。这种编码能够涵盖世界上所有的文字,字母,字符信息。


7.3 以字符形式给出的数据

如果学过C语言,那么很好理解当我们在C语言定义字符串的时候,字符串的每个字符都是以ASCII编码的方式在计算机中进行存储的。

汇编语言与一样我们可以把字符直接存储在'.....'中,这样程序会将'....'定义的字符以ASCII码存储在计算机中。看下面的程序:


这段程序定义了一个数据段ds和代码段cs,其中数据段存储了 'unIX' 和 'foRK'。

db 'unIX' 相当于db 75H,6EH,49H,58H 这四个数字分别代表了unIX四个字母的ASCII码

db 'foRK' 相当于db 66H,6FH,52H,4BH 这四个数字分别代表了foRK四个字母的ASCII码


mov al, 'a'相当于mov al,61H 61为字符a的ASCII码

mov al, 'b'相当于mov al,62H 62为字符b的ASCII码


接下来我们进行编译链接成vpoet并通过debug工具查看其寄存器和指令:


看到MOV AL,61和MOV BL,62可以证明实际上计算机内部的确是用ASCII来表示字符。

记下来我们在使用d命令查看数据段在内存中存储的内容:

果然数据段中定义的字符串在内存中也是按照字符的ASCII码依次存储的。


7.4 大小写转换问题

有如下代码段:


将第一个字符串'BaSiC'全部转换为大写,第二个字符串'iNforMaTiOn'全部转换为小写。


我们要考虑如下几个问题:

根据大写与小写字符的ASCII码值相差20H

小写转换为大写可以使用 小写字符ASCII码值-20H=大写字符ASCII码值

大写转换为小写可以使用 大写字符ASCII码值+20H=小写字符ASCII码值

但是问题来了我们当前还没学过汇编的加法和减法运算符。肿么办呢?

通过分析我们可以发现,当我们用二进制表示字符的ASCII码值的时候。大写与小写的诧异主要在第5位上。

比如a的ASCII值为97 二进制1100001

      A的ASCII值为65 二进制1000001

它们主要的区别在第五位,当大写的字符的时候第五位为1,当小写字符的时候第五位为0.所以这里我们可以用按位与和按位或

操作进行大小写转换。

实现代码如下:

<pre name="code" class="plain">assume cs:codesg,ds:datasgdatasg segmentdb 'BaSiC'db 'iNfOrMaTiOn'
datasg endscodesg segment
start: mov ax,datasgmov ds,axmov bx,0mov cx,5s:mov al,[bx]and al,11011111Bmov [bx],alinc bxloop smov bx,5mov cx,11s0:mov al,[bx]or al,00100000Bmov [bx],alinc bxloop s0mov ax 4c00hint 21h
codesg ends
end start


 

7.5 [bx+idata]

[bx]代表一个内存地址的偏移量。假设其段地址在ds中。那么[bx]可以表示值为((ds)*16+(bx))

[bx+idata]其中idata代表常量,同样表示一个地址:((ds)*16+(bx)+200)

7.6用[bx+idata]的方式进行数组的处理

我们接近着7.4的问题有如下的问题,同样是将第一个字符串转换为大写,第二个字符串转换为小写。

这次第一个字符串为'BaSiC'  第二个字符串为'MinIX' 两个字符串均为5个字符的字符串

在7.4中我们处理两个字符串的时候需要两次分别复制给bx字符串的起始偏移地址,第一个字符串偏移地址为mov bx,0

第二个字符串的偏移地址为mov bx,5

现在我们可以[bx+idata]方式进行改写

assume cs:codesg,ds:datasgdatasg segmentdb 'BaSiC'db 'MinIX'
datasg endscodesg segment
start: mov ax,datasgmov ds,axmov bx,0mov cx,5s:mov al,[bx]and al,11011111Bmov [bx],almov al,[bx+5]or al,00100000Bmov [bx+5],alinc bxloop smov ax 4c00hint 21h
codesg ends
end start

这里我们通过[bx]和[bx+5]分别索引两个字符串进行大小写转换,因为两个字符串的长度都是5,所以只需要一个循环即可将两个字符串一次性进行大小写转换的改写。


7.7 SI和DI

SI和DI与普通寄存器一样,但是SI和DI不能像AX一样分成AL和AH两个寄存器。

有如下问题,需要将'welcome to masm!'这个字符串复制到其之后的数据区。


代码如下:


这里我们还可以使用前面介绍的[bx+idata]方式:



7.8 [bx+si]和[bx+di]

假设段地址为ds,[bx+si]解释为((ds)*16+(bx)+(si))

假设段地址为ds,[bx+si]解释为((ds)*16+(bx)+(di))


7.9  [bx+si+idata]和[bx+di+idata]

假设段地址为ds,[bx+si+idata]解释为((ds)*16+(bx)+(si)+idata)

假设段地址为ds,[bx+di+idata]解释为((ds)*16+(bx)+(di)+idata)


7.10 不同的寻址方式的灵活应用

我们现在总结下所学的内存寻址方式:

[idata]用一个常量表示地址,可用于直接定位一个内存单元

[bx]用一个变量来保存内存地址,可用于间接定位一个内存单元

[bx+idata]用一个变量和常量表示地址,可在一个起始地址的基础上用变量间隔定位一个内存单元

[bx+si]用两个变量表示地址

[bx+si+idata]用两个变量和一个常量表示地址


请顶我一下~~~


这篇关于汇编语言学习第七章-更灵活的定位内存地址的方法的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

python获取网页表格的多种方法汇总

《python获取网页表格的多种方法汇总》我们在网页上看到很多的表格,如果要获取里面的数据或者转化成其他格式,就需要将表格获取下来并进行整理,在Python中,获取网页表格的方法有多种,下面就跟随小编... 目录1. 使用Pandas的read_html2. 使用BeautifulSoup和pandas3.

Spring 中的循环引用问题解决方法

《Spring中的循环引用问题解决方法》:本文主要介绍Spring中的循环引用问题解决方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录什么是循环引用?循环依赖三级缓存解决循环依赖二级缓存三级缓存本章来聊聊Spring 中的循环引用问题该如何解决。这里聊

Java学习手册之Filter和Listener使用方法

《Java学习手册之Filter和Listener使用方法》:本文主要介绍Java学习手册之Filter和Listener使用方法的相关资料,Filter是一种拦截器,可以在请求到达Servl... 目录一、Filter(过滤器)1. Filter 的工作原理2. Filter 的配置与使用二、Listen

Pandas统计每行数据中的空值的方法示例

《Pandas统计每行数据中的空值的方法示例》处理缺失数据(NaN值)是一个非常常见的问题,本文主要介绍了Pandas统计每行数据中的空值的方法示例,具有一定的参考价值,感兴趣的可以了解一下... 目录什么是空值?为什么要统计空值?准备工作创建示例数据统计每行空值数量进一步分析www.chinasem.cn处

Windows 上如果忘记了 MySQL 密码 重置密码的两种方法

《Windows上如果忘记了MySQL密码重置密码的两种方法》:本文主要介绍Windows上如果忘记了MySQL密码重置密码的两种方法,本文通过两种方法结合实例代码给大家介绍的非常详细,感... 目录方法 1:以跳过权限验证模式启动 mysql 并重置密码方法 2:使用 my.ini 文件的临时配置在 Wi

MySQL重复数据处理的七种高效方法

《MySQL重复数据处理的七种高效方法》你是不是也曾遇到过这样的烦恼:明明系统测试时一切正常,上线后却频频出现重复数据,大批量导数据时,总有那么几条不听话的记录导致整个事务莫名回滚,今天,我就跟大家分... 目录1. 重复数据插入问题分析1.1 问题本质1.2 常见场景图2. 基础解决方案:使用异常捕获3.

最详细安装 PostgreSQL方法及常见问题解决

《最详细安装PostgreSQL方法及常见问题解决》:本文主要介绍最详细安装PostgreSQL方法及常见问题解决,介绍了在Windows系统上安装PostgreSQL及Linux系统上安装Po... 目录一、在 Windows 系统上安装 PostgreSQL1. 下载 PostgreSQL 安装包2.

SQL中redo log 刷⼊磁盘的常见方法

《SQL中redolog刷⼊磁盘的常见方法》本文主要介绍了SQL中redolog刷⼊磁盘的常见方法,将redolog刷入磁盘的方法确保了数据的持久性和一致性,下面就来具体介绍一下,感兴趣的可以了解... 目录Redo Log 刷入磁盘的方法Redo Log 刷入磁盘的过程代码示例(伪代码)在数据库系统中,r

Python实现图片分割的多种方法总结

《Python实现图片分割的多种方法总结》图片分割是图像处理中的一个重要任务,它的目标是将图像划分为多个区域或者对象,本文为大家整理了一些常用的分割方法,大家可以根据需求自行选择... 目录1. 基于传统图像处理的分割方法(1) 使用固定阈值分割图片(2) 自适应阈值分割(3) 使用图像边缘检测分割(4)

Java中Switch Case多个条件处理方法举例

《Java中SwitchCase多个条件处理方法举例》Java中switch语句用于根据变量值执行不同代码块,适用于多个条件的处理,:本文主要介绍Java中SwitchCase多个条件处理的相... 目录前言基本语法处理多个条件示例1:合并相同代码的多个case示例2:通过字符串合并多个case进阶用法使用