汇编语言学习第八章-数据处理的两个基本问题

2024-08-25 05:18

本文主要是介绍汇编语言学习第八章-数据处理的两个基本问题,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

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


        计算机CPU进行数据处理包括两个基本的问题:1.数据在何处?     2.数据有多大?  本章作为一个前面内容的总结性章节,主要来说明这两个问题。我们定义两个符号reg和sreg。其中reg为寄存器,sreg为段寄存器

      reg包括:ax,bx,cx,dx,ah,al,bh,bl,ch,cl,dh,dl,sp,bp,si,di

      sreg包括:ds,ss,sp,es


8.1  bx、 si、 di和bp

1.在8086CPU只有bx,si,di以及bp这四个寄存器可以用在'[...]'中进行内存寻址:

比如下面的指令是正确的:

mov ax,[bx]
mov ax,[bx+si]
mov ax,[bx+di]
mov ax,[bp]
mov ax,[bp+si]
mov ax,[bp+di]

下面的指令是不正确的:

mov ax,[cx]
mov ax,[ax]
mov ax,[dx]
mov ax,[ds]

2. bx,si,di以及bp 这四个寄存器只有如下四种组合。bx与si,bx与di,bp与si,bp与di

比如下面的指令是正确的:

mov ax,[bx]
mov ax,[si]
mov ax,[di]
mov ax,[bp]
mov ax,[bx+si]
mov ax,[bx+di]
mov ax,[bp+si]
mov ax,[bp+di]
mov ax,[bx+si+idata]
mov ax,[bx+di+idata]
mov ax,[bp+si+idata]
mov ax,[bp+di+idata]


下面的指令是错误的:

mov ax,[bx+bp]
mov ax,[si+di]

3.只要再'[....]'使用寄存器bp寻址,段寄存器默认在ss中。

比如如下指令:

mov ax,[bp]            (ax)=((ss)*16+(bp))
mov ax,[bp+idata]      (ax)=((ss)*16+(bp)+idata)
mov ax,[bp+si]         (ax)=((ss)*16+(bp)+(si))
mov ax,[bp+si+idata]   (ax)=((ss)*16+(bp)+(si)+idata)



8.2 机器指令处理的数据在什么地方
在执行机器指令的时候,我们往往总是关心执行指令所需的数据存储在什么地方。数据往往存储在三个地方:CPU内部(寄存器),内存以及端口。

下图说明了指令存储数据的位置:



8.3 汇编语言中数据位置的表达

(1)立即数:

直接包涵在汇编指令中的数据称为立即数(执行前在CPU中的指令缓冲区)

例如: mov ax,1

        add bx,2000h


(2)寄存器

执行指令所需要的数据在寄存器中:

比如: mov ax,bx

        push bx


(3)段地址和偏移地址

指令要处理的数据在内存中则需要段地址加偏移地址进行寻址

段地址可以是默认给出的(默认ds):

比如:mov ax,[0](默认段地址ds)

       mov ax,[di](默认段地址ds)

       mov ax,[bp](默认段地址ss)

       mov ax,[bp+si](默认段地址ss)

也可以显示给出段地址:
比如:mov ax,ds:[0]

        mov ax,ds:[bp]



8.4 寻址方式

当数据存储在内存的时候,我们有多种方法可以求得其偏移地址,求得偏移地址的方法称为寻址方式。下图为所有的寻址方式的总结。



8.5 指令要处理的数据有多长

如何指定要处理的数据有多大有如下方式:

1.通过寄存器指明要处理数据的大小

比如字操作: mov ax,ds:[0]

比如字节操作: mov al,ds:[0]


2.在没有寄存器的情况下,可以使用X ptr指明需要处理数据大小。X可以为word或byte

比如字操作: mov word ptr ds:[0],1

比如字节操作: mov byte ptr ds:[0],1


3.有些指令默认访问数据大小

比如 push 指令

push [1000H]默认进行字操作


8.6寻址方式的综合应用

假设一个公司的的数据存放在seg:60h为起始地址的内存区域,如下:


现在要个将137改为38,将40改为70,将'PDP'改为'VAX'

我们可以通过[bx+si+idata]方式来寻址,同时用X PTR指定要更改数据的长度。所以核心程序如下:



8.7  div指令

div指令的注意事项如下:

1.除数:有8位和16位两种,在一个reg和内存单元中。

2.被除数:默认放在AX或DX和AX中,如果除数为8位,则被除数为16位,默认在AX中存放;如果除数为16位,则被除数为32位,在DX和AX中存放,DX存放高16位,AX存放地16位

3.结果:如果除数为8位,则AL存储商,AH存储余数。如果除数为16位,则AX存储商,DX存储余数。


格式如下:

div reg

div 内存单元


比如:

div byte ptr ds:[0]

含义:(al)=(ax)/((ds)*16+0)的商    (ah)=(ax)/((ds)*16+0)的余数

div word ptr [bx+si+8]

含义:

(ax)=[(dx)*10000h+(ax)]/((ds)*16+(bx)+(si)+8)的商

(dx)=[(dx)*10000h+(ax)]/((ds)*16+(bx)+(si)+8)的商



8.8伪指令dd

dw,db,dd

其中dw为定义一个字空间,db为定义一个字节空间,dd为定义一个双字的空间


8.9  dup

dup也是一个伪指令,是由编译器识别的。往往dup配合着dw,db,dd使用进行数据的重复。

比如:

db 3 dup (0)

定义了三个字节,它们的值都为0,相当于 db 0,0,0

db 3 dup (0,1,2)

定义了九个字节,它们的值为0,1,2,0,1,2,0,1,2相当于 db 0,1,2,0,1,2,0,1,2


这篇关于汇编语言学习第八章-数据处理的两个基本问题的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

usb接口驱动异常问题常用解决方案

《usb接口驱动异常问题常用解决方案》当遇到USB接口驱动异常时,可以通过多种方法来解决,其中主要就包括重装USB控制器、禁用USB选择性暂停设置、更新或安装新的主板驱动等... usb接口驱动异常怎么办,USB接口驱动异常是常见问题,通常由驱动损坏、系统更新冲突、硬件故障或电源管理设置导致。以下是常用解决

Mysql如何解决死锁问题

《Mysql如何解决死锁问题》:本文主要介绍Mysql如何解决死锁问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录【一】mysql中锁分类和加锁情况【1】按锁的粒度分类全局锁表级锁行级锁【2】按锁的模式分类【二】加锁方式的影响因素【三】Mysql的死锁情况【1

SpringBoot内嵌Tomcat临时目录问题及解决

《SpringBoot内嵌Tomcat临时目录问题及解决》:本文主要介绍SpringBoot内嵌Tomcat临时目录问题及解决,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,... 目录SprinjavascriptgBoot内嵌Tomcat临时目录问题1.背景2.方案3.代码中配置t

SpringBoot使用GZIP压缩反回数据问题

《SpringBoot使用GZIP压缩反回数据问题》:本文主要介绍SpringBoot使用GZIP压缩反回数据问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录SpringBoot使用GZIP压缩反回数据1、初识gzip2、gzip是什么,可以干什么?3、Spr

如何解决idea的Module:‘:app‘platform‘android-32‘not found.问题

《如何解决idea的Module:‘:app‘platform‘android-32‘notfound.问题》:本文主要介绍如何解决idea的Module:‘:app‘platform‘andr... 目录idea的Module:‘:app‘pwww.chinasem.cnlatform‘android-32

kali linux 无法登录root的问题及解决方法

《kalilinux无法登录root的问题及解决方法》:本文主要介绍kalilinux无法登录root的问题及解决方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,... 目录kali linux 无法登录root1、问题描述1.1、本地登录root1.2、ssh远程登录root2、

MySQL 中的 LIMIT 语句及基本用法

《MySQL中的LIMIT语句及基本用法》LIMIT语句用于限制查询返回的行数,常用于分页查询或取部分数据,提高查询效率,:本文主要介绍MySQL中的LIMIT语句,需要的朋友可以参考下... 目录mysql 中的 LIMIT 语句1. LIMIT 语法2. LIMIT 基本用法(1) 获取前 N 行数据(

SpringBoot应用中出现的Full GC问题的场景与解决

《SpringBoot应用中出现的FullGC问题的场景与解决》这篇文章主要为大家详细介绍了SpringBoot应用中出现的FullGC问题的场景与解决方法,文中的示例代码讲解详细,感兴趣的小伙伴可... 目录Full GC的原理与触发条件原理触发条件对Spring Boot应用的影响示例代码优化建议结论F

MySQL 中查询 VARCHAR 类型 JSON 数据的问题记录

《MySQL中查询VARCHAR类型JSON数据的问题记录》在数据库设计中,有时我们会将JSON数据存储在VARCHAR或TEXT类型字段中,本文将详细介绍如何在MySQL中有效查询存储为V... 目录一、问题背景二、mysql jsON 函数2.1 常用 JSON 函数三、查询示例3.1 基本查询3.2

Pyserial设置缓冲区大小失败的问题解决

《Pyserial设置缓冲区大小失败的问题解决》本文主要介绍了Pyserial设置缓冲区大小失败的问题解决,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面... 目录问题描述原因分析解决方案问题描述使用set_buffer_size()设置缓冲区大小后,buf