【汇编】[bx+idata]的寻址方式、SI和DI寄存器

文章目录

  • 前言
  • 一、[bx+idata]寻址方式
    • 1.1 [bx+idata]的含义
    • 1.2 示例代码
  • 二、SI和DI寄存器
    • 2.1 SI和DI寄存器是什么?
    • 2.2 [bx+si]和[bx+di]方式寻址
    • 2.3 [bx+si+idata]和[bx+di+idata]
  • 总结


前言

在汇编语言中,寻址方式是指指令如何定位内存中的数据。BX寄存器与偏移量(idata)的结合,即[BX+idata]寻址方式,是一种常见的寻址方式。同时,SI(Source Index)和DI(Destination Index)寄存器在字符串操作中扮演着重要的角色。本文将深入研究这两个方面,旨在帮助读者更好地理解在汇编语言中是如何定位和操作内存中的数据的。

[BX+idata]的寻址方式:

在汇编语言中,[BX+idata] 是一种寻址方式,其中BX是基址寄存器,idata是一个立即数偏移。这种寻址方式的具体操作如下:

从BX寄存器中取得一个地址。
将这个地址与idata相加,得到最终的内存地址。
访问该内存地址中的数据。
这种寻址方式通常用于数组和结构体等数据结构的访问,BX提供了数组或结构体的基址,而idata提供了相对于基址的偏移。

SI和DI寄存器:

SI寄存器(Source Index):

SI寄存器常用于字符串和数组的操作。在字符串复制或比较等操作中,SI通常指向源数据的起始位置。
操作系统和编程语言通常约定好使用SI寄存器来处理源数据。
DI寄存器(Destination Index):

DI寄存器同样常用于字符串和数组的操作。在字符串复制时,DI通常指向目标数据的起始位置。
DI寄存器通常用于指定写入数据的目标位置。


一、[bx+idata]寻址方式

1.1 [bx+idata]的含义

[bx+idata]表示一个内存单元,它的偏移地址为(bx)+idata(bx中的数值加上idata)。
mov ax,[bx+200] / mov ax, [200+bx] 的含义
将一个内存单元的内容送入ax
这个内存单元的长度为2字节(字单元),存放一个字
内存单元的段地址在ds中,偏移地址为200加上bx中的数值
数学化的描述为: (ax)=((ds)*16+200+(bx))
指令mov ax,[bx+200]的其他写法(常用)

mov ax,[200+bx]
mov ax,200[bx]
mov ax,[bx].200

在这里插入图片描述
有了[bx+idata]这种表示内存单元的方式,我们就可以用更高级的结构来看待所要处理的数据。

弟子想到了C语言中的数组

1.2 示例代码

用[bx+idata]的方式进行数组的处理
问题:在codesg中填写代码,将datasg中定义的
第一个字符串,转化为大写
第二个字符串转化为小写。

assume cs:codesg,ds:data
codesg segmentdata segmentdb 'BaSic'db 'iNfOrMaTiOn'
data endsstart:  mov ax,datasgmov ds,axmov bx,0mov cx,5s: mov al,[bx]and al,11011111bmov [bx],alinc bxloop smov bx,5mov cx,5s0: mov al,[bx]or al,00100000bmov [bx],alinc bxloop s0mov ax,4c00hint 21hcodesg ends
end start

这段汇编代码的作用是处理一个包含字符串 “BaSic iNfOrMaTiOn” 的内存区域。现在,我会用通俗易懂的语言逐步解释这段代码的主要部分:

1.数据段定义:

data segment
db ‘BaSic’
db ‘iNfOrMaTiOn’
data ends

在这里,我们定义了一个数据段 data,其中包含两个字符串片段,分别是 ‘BaSic’ 和 ‘iNfOrMaTiOn’。

2.数据移动和处理:

mov ax, datasg
mov ds, ax
mov bx, 0
mov cx, 5
s: mov al, [bx]
and al, 11011111b
mov [bx], al
inc bx
loop s

这部分代码的作用是将字符串中的大写字母转换为小写。通过循环遍历字符串,每次取出一个字符,使用 and 操作将ASCII码中的高位置0,从而将大写字母转换为小写字母。

3.数据移动和处理的第二部分:

mov bx, 5
mov cx, 5
s0: mov al, [bx]
or al, 00100000b
mov [bx], al
inc bx
loop s0

这一部分代码的作用是将字符串中的小写字母转换为大写。同样通过循环遍历字符串,每次取出一个字符,使用 or 操作将ASCII码中的指定位设为1,从而将小写字母转换为大写字母。

4.程序结束:

mov ax, 4c00h
int 21h

最后的部分是程序的结束。通过 mov ax, 4c00h 将程序结束的指令存储在寄存器 ax 中,然后通过 int 21h 中断调用,正常地退出程序。
综合起来,这段代码的主要功能是将给定字符串中的大写字母转换为小写,同时将小写字母转换为大写,然后正常地结束程序。

二、SI和DI寄存器

2.1 SI和DI寄存器是什么?

在汇编语言中,SI(Source Index)和DI(Destination Index)寄存器通常用于字符串操作。让我们用通俗易懂的语言来解释它们:

SI 寄存器(Source Index):

直译: “源索引”
比方说: 想象你有一本书,你要找一段文字的起始位置。SI 就像是你在书中的索引,告诉你这段文字在哪里。
DI 寄存器(Destination Index):

直译: “目标索引”
比方说: 现在你想在另一本书里找到相同的文字,并且要从这本书的某一页开始写下来。DI 就像是你在另一本书中的索引,告诉你从哪里开始写。
在字符串操作中,SI 通常用于指向源字符串的起始位置,而 DI 用于指向目标字符串的起始位置。例如,当你想把一个字符串复制到另一个地方时,SI 就是原始字符串的起点,DI 是要复制到的目标地点。这两个寄存器的值会在操作过程中不断地增加,以便逐步处理字符串的每个字符。

2.2 [bx+si]和[bx+di]方式寻址

[bx+si]表示一个内存单元
偏移地址为(bx)+(si)(即bx中的数值加上si中的数值)。
指令mov ax,[bx+si]的含义
将一个内存单元的内容送入ax
这个内存单元的长度为2字节(字单元),存放一个字
偏移地址为bx中的数值加上si中的数值
段地址在ds中
指令mov ax,[bx+si]的数学化的描述
(ax)=( (ds)*16+(bx)+(si) )
mov ax,[bx+si]的其他写法
mov ax,[bx][si]

在这里插入图片描述

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

[bx+si+idata]和[bx+di+idata]方式指定地址
[bx+si+idata]表示一个内存单元
偏移地址为(bx)+(si)+idata,即bx中的数值加上si中的数值再加上idata
指令mov ax,[bx+si+idata]的含义
将一个内存单元的内容送入ax
这个内存单元的长度为2字节(字单元),存放一个字
偏移地址为bx中的数值加上si中的数值再加上idata,段地址在ds中

数学化的描述
(ax)=( (ds)*16+(bx)+(si)+idata )
指令mov ax,[bx+si+idata]的其他写法

mov ax,[bx+200+si]
mov ax,[200+bx+si]
mov ax,200[bx][si]
mov ax,[bx].200[si]
mov ax,[bx][si].200
mov ax,[bx][si]

总结

在本文中,我们深入研究了在汇编语言中的两个重要概念:[BX+idata]寻址方式以及SI和DI寄存器。[BX+idata]寻址方式提供了一种灵活的方式来访问内存中的数据,特别适用于数组和结构体的操作。而SI和DI寄存器在字符串和数组处理中发挥着关键的作用,分别指向源数据和目标数据的起始位置,使得汇编语言能够有效地进行字符串操作,如复制、比较等。通过深入理解这些概念,读者将更好地理解汇编语言中的内存寻址和字符串处理的原理。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/198306.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

storage和正则表达式

一、Storage 1.认识Storage WebStorage主要提供了一种机制,可以让浏览器提供一种比cookie更直观的key、value存储方式: localStorage:本地存储,提供的是一种永久性的存储方法,在关闭掉网页重新打开时,存…

c语言-输入输出详解

文章目录 格式化输入输出占位符printfscanf 字符串输入输出puts&#xff08;&#xff09;gets&#xff08;&#xff09; 字符输入输出putchar&#xff08;&#xff09;getchar&#xff08;&#xff09; 区别 格式化输入输出 输入输出的库函数的头文件&#xff1a; #include<…

数据结构 堆

手写堆&#xff0c;而非stl中的堆 如何手写一个堆&#xff1f; //将数组建成堆 <O(n) for (int i n / 2;i;i--) //从n/2开始down down(i); 从n/2元素开始down&#xff0c;最下面一层元素的个数是n/2&#xff0c;其余上面的元素的个数是n/2&#xff0c;从最下面一层到最高层…

【论文复现】QuestEval:《QuestEval: Summarization Asks for Fact-based Evaluation》

以下是复现论文《QuestEval: Summarization Asks for Fact-based Evaluation》&#xff08;NAACL 2021&#xff09;代码https://github.com/ThomasScialom/QuestEval/的流程记录&#xff1a; 在服务器上conda创建虚拟环境questeval&#xff08;python版本于readme保持一致&…

【洛谷算法题】P5713-洛谷团队系统【入门2分支结构】

&#x1f468;‍&#x1f4bb;博客主页&#xff1a;花无缺 欢迎 点赞&#x1f44d; 收藏⭐ 留言&#x1f4dd; 加关注✅! 本文由 花无缺 原创 收录于专栏 【洛谷算法题】 文章目录 【洛谷算法题】P5713-洛谷团队系统【入门2分支结构】&#x1f30f;题目描述&#x1f30f;输入格…

C++--哈希表--散列--冲突--哈希闭散列模拟实现

文章目录 哈希概念一、哈希表闭散列的模拟实现二、开散列(哈希桶)的模拟实现数据类型定义析构函数插入查找删除 哈希概念 unordered系列的关联式容器之所以效率比较高&#xff0c;是因为其底层使用了哈希结构。 顺序结构以及平衡树中&#xff0c;元素关键码与其存储位置之间没…

C#WPF文本转语音实例

本文介绍C#WPF文本转语音实例 实现方法:使用类库(SpeechSynthesizer )实现的。 一、首先是安装程序包。 二、创建项目 需要添加引用using System.Speech.Synthesis; UI界面 <Windowx:Class="TextToSpeechDemo.MainWindow"xmlns="http://schemas.micr…

JVM垃圾回收相关概念

目录 一、System.gc()的理解 二、内存溢出与内存泄露 &#xff08;一&#xff09;OOM &#xff08;二&#xff09;内存泄露 三、StopTheWorld 四、垃圾回收的并行与并发 五、安全点与安全区域 &#xff08;一&#xff09;安全点 &#xff08;二&#xff09;安全区域 …

【JavaEE初阶】计算机是如何工作的

一、计算机发展史 计算的需求在⼈类的历史中是广泛存在的&#xff0c;发展大体经历了从⼀般计算⼯具到机械计算机到目前的电子计算机的发展历程。 人类对计算的需求&#xff0c;驱动我们不断的发明、改善计算机。目前这个时代是“电子计算机”的时代&#xff0c;发展的潮流是…

Qt按钮大全续集(QCommandLinkButton和QDialogButtonBox )

## QCommandLinkButton 控件简介 QCommandLinkButton 控件中文名是“命令链接按钮”。QCommandLinkButton 继承QPushButton。CommandLinkButton 控件和 RadioButton 相似,都是用于在互斥选项中选择一项。表面上同平面按钮一样,但是 CommandLinkButton 除带有正常的按钮上的文…

通过汇编理解cortex-m3:第0章

第0章&#xff1a;准备工作 基本想法&#xff1a;利用汇编和gdb调试&#xff0c;来学习cortex-m3汇编指令&#xff0c;以及一些寄存器的功能。 软件和硬件&#xff1a; 硬件&#xff1a;韦东山瑞士军刀中的最小核心板&#xff08;STM32F103C8T6&#xff09; STLINK-V2&#…

初刷leetcode题目(3)——数据结构与算法

&#x1f636;‍&#x1f32b;️&#x1f636;‍&#x1f32b;️&#x1f636;‍&#x1f32b;️&#x1f636;‍&#x1f32b;️Take your time ! &#x1f636;‍&#x1f32b;️&#x1f636;‍&#x1f32b;️&#x1f636;‍&#x1f32b;️&#x1f636;‍&#x1f32b;️…

ROS参数服务器(Param):通信模型、Hello World与拓展

参数服务器在ROS中主要用于实现不同节点之间的数据共享。 参数服务器相当于是独立于所有节点的一个公共容器&#xff0c;可以将数据存储在该容器中&#xff0c;被不同的节点调用&#xff0c;当然不同的节点也可以往其中存储数据。 使用场景一般存储一些机器人的固有参数&…

C语言实现冒泡排序(超详细)

排序算法 - 冒泡排序 什么是冒泡排序&#xff1f;冒泡排序有啥用呢&#xff1f;冒泡排序的实现代码讲解冒泡排序的总结 什么是冒泡排序&#xff1f; 冒泡排序是一种简单的排序算法&#xff0c;它重复地遍历要排序的列表&#xff0c;一次比较两个元素&#xff0c;如果它们的顺序…

OpenHarmony源码下载

OpenHarmony源码下载 现在的 OpenHarmony 4.0 源码已经有了&#xff0c;在 https://gitee.com/openharmony 地址中&#xff0c;描述了源码获取的方式&#xff0c;但那是基于 ubuntu 或者说是 Linux 的下载方式。在 windows 平台下的下载方式没有做出介绍。 我自己尝试了 wind…

Python 爬虫入门

文章目录 Python 爬虫入门requests 库beautifulsoup4库函数findall()&#xff0c;find()函数get() 爬虫实例 1&#xff1a;抓小说爬虫实例 2&#xff1a;抓豆瓣 top 250 的电影信息后记 Python 爬虫入门 Python 的爬虫功能使得程序员可以快速抓取并分析网页中的信息&#xff0…

Spring Cloud学习(十)【Elasticsearch搜索功能 分布式搜索引擎02】

文章目录 DSL查询文档DSL查询分类全文检索查询精准查询地理坐标查询组合查询相关性算分Function Score Query复合查询 Boolean Query 搜索结果处理排序分页高亮 RestClient查询文档快速入门match查询精确查询复合查询排序、分页、高亮 黑马旅游案例 DSL查询文档 DSL查询分类 …

大数据HCIE成神之路之数学(2)——线性代数

线性代数 1.1 线性代数内容介绍1.1.1 线性代数介绍1.1.2 代码实现介绍 1.2 线性代数实现1.2.1 reshape运算1.2.2 转置实现1.2.3 矩阵乘法实现1.2.4 矩阵对应运算1.2.5 逆矩阵实现1.2.6 特征值与特征向量1.2.7 求行列式1.2.8 奇异值分解实现1.2.9 线性方程组求解 1.1 线性代数内…

谈谈如何写作(二)

序言 没有什么比一套好理论更有用了。——库尔特勒温 谈谈如何写作系列今天进入第二篇&#xff0c;第一篇请速戳&#xff1a;谈谈如何写作&#xff08;一&#xff09; 今天&#xff0c;博主从如何写报告讲起。 Q&#xff1a;如何写报告 如何写报告呢&#xff1f; 当每位盆友接到…

【华为HCIP | 华为数通工程师】刷题日记1116(一个字惨)

个人名片&#xff1a; &#x1f43c;作者简介&#xff1a;一名大三在校生&#xff0c;喜欢AI编程&#x1f38b; &#x1f43b;‍❄️个人主页&#x1f947;&#xff1a;落798. &#x1f43c;个人WeChat&#xff1a;hmmwx53 &#x1f54a;️系列专栏&#xff1a;&#x1f5bc;️…