《汇编语言》第3版 (王爽)检测点3.1解析

2024-03-02 05:28

本文主要是介绍《汇编语言》第3版 (王爽)检测点3.1解析,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

第三章 检测点3.1


(1).在Debug中,用“d 0:0 1f”查看内存,结果如下。
在这里插入图片描述
下面的程序执行前,AX = 0,BX = 0,写出每条汇编指令执行完后相关寄存器中的值。

mov ax,1  ;1放入AX寄存器中,此时AX寄存器中的值为1
mov ds,ax ;将AX寄存器中的值放入DS寄存器中,此时DS寄存器中的值为1
mov ax,[0000]    AX = 2662  ;此时的内存单元地址为 DS*16+0=00010H,即将2662放入AX寄存器中
mov bx,[0001]    BX = E626  ;将内存单元地址为00011H的数据放入BX寄存器中,即为E626
mvo ax,bx        AX = E626  ;将BX寄存器中的数据放入AX寄存器中
mov ax,[0000]    AX = 2662  ;和第三条指令相同
mov bx,[0002]    BX = D6E6  ;将内存单元00012H的数据放入BX寄存器中
add ax,bx        AX = FD48  ;将BX寄存器中的数据和AX寄存器中的数据相加后存入AX中,即 D6E6 + 2662 = FD48
add ax,[0004]    AX = 2C14  ;将内存单元00014H中的数据和AX寄存器中的数据相加后放入AX中,即 FD48 + 2ECC = 12C14,注意此时数据已经超出AX寄存器所能存放的范围,所以只保留低16位
mov ax,0         AX = 0    ;0放入AX寄存器中
mov al,[0002]    AX = 00E6 ;将内存单元00012H中的数据放入AX寄存器的低八位中,由于操作的是低八位寄存器,所以此时按字节存放,即E6
mov bx,0         BX = 0    ;0放入BX寄存器中
mov bl,[000C]    BX = 0026 ;将内存单元0001CH中的数据放入BX寄存器的低八位
add al,bl        AX = 000C ;将BX寄存器低八位中的数据和AX寄存器低八位中的数据相加后放入AX寄存器中的低八位,即 E6 + 26 = 10C,注意此时数据已超过AL的范围,所以只保留低8

(2).内存中的情况如图3.6所示
在这里插入图片描述

各寄存器的初始值:CS = 2000H,IP = 0,DS = 1000H,AX = 0,BX = 0;
①写出CPU执行的指令序列(用汇编指令写出)
②写出CPU执行每条指令后,CS、IP和相关寄存器中的数值
③再次体会:数据和程序有区别吗?如何确定内存中的信息哪些是数据,哪些是程序?

mov ax,6622H   ;AX = 6622H  CS = 2000H  IP = 0003H 将6622放入AX寄存器中,这条指令为3个字节,所以CS不变,IP+3
jmp 0ff0:0100  ;CS = 0FF0H  IP = 0100H 这是一条跳转语句,跳转到CS=0FF0,IP=0100的地址
mov ax,2000H   ;AX = 2000H  CS = 0FF0H  IP = 0103H 将2000放入AX寄存器中,这条指令为3个字节,所以CS不变,IP+3
mov ds,ax      ;AX = 2000H  DS = 2000H  CS = 0FF0H  IP = 0105H 将AX寄存器中的内容放入DS中,这条指令为3个字节,所以CS不变,IP+3
mov ax,[0008]  ;AX = C389H  CS = 0FF0H  IP = 0108H 将内存单元为20008中的数据放入AX寄存器中,我们从图3.6可以看到内存单元地址为20008中存放的是89 C3,所以此时AX寄存器中的值为C389,注意此时是用DS+[xxxx]从某内存单元中取数据
mov ax,[0002]  ;AX = EA66H  CS = 0FF0H  IP = 010BH 将内存单元为20002中的数据放人AX寄存器中

具体调试过程如下图:
在这里插入图片描述
在这里插入图片描述
通过上述过程,我们可以知道使用CS和IP读取的是指令,而是用DS和[xxxx]读取的是数据。

这篇关于《汇编语言》第3版 (王爽)检测点3.1解析的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

MySQL中FIND_IN_SET函数与INSTR函数用法解析

《MySQL中FIND_IN_SET函数与INSTR函数用法解析》:本文主要介绍MySQL中FIND_IN_SET函数与INSTR函数用法解析,本文通过实例代码给大家介绍的非常详细,感兴趣的朋友一... 目录一、功能定义与语法1、FIND_IN_SET函数2、INSTR函数二、本质区别对比三、实际场景案例分

Java图片压缩三种高效压缩方案详细解析

《Java图片压缩三种高效压缩方案详细解析》图片压缩通常涉及减少图片的尺寸缩放、调整图片的质量(针对JPEG、PNG等)、使用特定的算法来减少图片的数据量等,:本文主要介绍Java图片压缩三种高效... 目录一、基于OpenCV的智能尺寸压缩技术亮点:适用场景:二、JPEG质量参数压缩关键技术:压缩效果对比

关于WebSocket协议状态码解析

《关于WebSocket协议状态码解析》:本文主要介绍关于WebSocket协议状态码的使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录WebSocket协议状态码解析1. 引言2. WebSocket协议状态码概述3. WebSocket协议状态码详解3

CSS Padding 和 Margin 区别全解析

《CSSPadding和Margin区别全解析》CSS中的padding和margin是两个非常基础且重要的属性,它们用于控制元素周围的空白区域,本文将详细介绍padding和... 目录css Padding 和 Margin 全解析1. Padding: 内边距2. Margin: 外边距3. Padd

Oracle数据库常见字段类型大全以及超详细解析

《Oracle数据库常见字段类型大全以及超详细解析》在Oracle数据库中查询特定表的字段个数通常需要使用SQL语句来完成,:本文主要介绍Oracle数据库常见字段类型大全以及超详细解析,文中通过... 目录前言一、字符类型(Character)1、CHAR:定长字符数据类型2、VARCHAR2:变长字符数

使用Jackson进行JSON生成与解析的新手指南

《使用Jackson进行JSON生成与解析的新手指南》这篇文章主要为大家详细介绍了如何使用Jackson进行JSON生成与解析处理,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1. 核心依赖2. 基础用法2.1 对象转 jsON(序列化)2.2 JSON 转对象(反序列化)3.

Springboot @Autowired和@Resource的区别解析

《Springboot@Autowired和@Resource的区别解析》@Resource是JDK提供的注解,只是Spring在实现上提供了这个注解的功能支持,本文给大家介绍Springboot@... 目录【一】定义【1】@Autowired【2】@Resource【二】区别【1】包含的属性不同【2】@

SpringCloud动态配置注解@RefreshScope与@Component的深度解析

《SpringCloud动态配置注解@RefreshScope与@Component的深度解析》在现代微服务架构中,动态配置管理是一个关键需求,本文将为大家介绍SpringCloud中相关的注解@Re... 目录引言1. @RefreshScope 的作用与原理1.1 什么是 @RefreshScope1.

Java并发编程必备之Synchronized关键字深入解析

《Java并发编程必备之Synchronized关键字深入解析》本文我们深入探索了Java中的Synchronized关键字,包括其互斥性和可重入性的特性,文章详细介绍了Synchronized的三种... 目录一、前言二、Synchronized关键字2.1 Synchronized的特性1. 互斥2.

Java的IO模型、Netty原理解析

《Java的IO模型、Netty原理解析》Java的I/O是以流的方式进行数据输入输出的,Java的类库涉及很多领域的IO内容:标准的输入输出,文件的操作、网络上的数据传输流、字符串流、对象流等,这篇... 目录1.什么是IO2.同步与异步、阻塞与非阻塞3.三种IO模型BIO(blocking I/O)NI