时间:2021-05-19
这篇文章主要介绍了汇编语言 寄存器内存访问原理解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
在内存中字的存储
这段话的主要意思是:一个字=2B=16bit,CPU中是用两个内存单元储存一个字(假如获取0地址存放的字型数据,就是获取它的高位字节0+1位和低位字节0位的数据,数据由高地址位向低地址位读)
问题:
(1)0地址单元中存放的字节型数据是多少? # 20H
(2)0地址字单元中存放的字型数据是多少? # 4e20H
(3)2地址字单元中存放的字节型数据是多少? # 12H
(4)2地址单元中存放的字型数据是多少? # 0012H
(5)1地址字单元中存放的字型数据是多少? # 12aEH
结论:就是我上面说的,字型数据就是它和它的下一位地址单元的数据(数据由高地址位向低地址位读)
数据段寄存器DS和偏移量[address]
用法和cs和ip差不多,都是段寄存器的值*16+偏移量的值
为给DS数据段寄存器值
因为CPU的段寄存器都比较害羞,没法给他们直接赋值(cs代码寄存器用的是jmp cs:ip),所以段寄存器采用以下方法赋值
字的传送
问题1:
内存中的情况如下图,写出下面指令执行后寄存器ax,bx,cx中的值?
解析:
问题2:
内存中的情况如下图,写出下面指令执行后寄存器ax,bx,cx中的值?
解析:
NB的move指令
sub,add指令
数据段
我们上面操作的实际上就是数据段,具体来看下是怎样操作数据段的
累加123B0H~123BAH的内存单元的操作
小结:
(1)字在内存中存储时 ,要用两个地址连续的内存单元来存放,字的低位字节存放在低地址单元中,高位字节存放再高地址单元中。
(2)用 mov 指令要访问内存单元,可以在mov指令中只给出单元的偏移地址,此时,段地址默认在DS寄存器中。
(3)[address]表示一个偏移地址为address的内存单元。
(4)在内存和寄存器之间传送字型数据时,高地址单元和高8位寄存器、低地址单元和低8位寄存器相对应。
(5)mov、add、sub是具有两个操作对象的指令。jmp是具有一个操作对象的指令。
(2) 内存中的情况如图3.6所示
各寄存器的初始值:cs=2000h,ip=0,ds=1000h,ax=0,bx=0;
① 写出CPU执行的指令序列(用汇编指令写出)。
② 写出CPU执行每条指令后,CS、IP和相关寄存器的数值。
③ 再次体会:数据和程序有区别吗?如何确定内存中的信息哪些是数据,哪些是程序?
答案:我以为jmp了以后cp的值也会改变,实际上就是它jmp的内个CP:IP
指令序列
CS
IP
DS
AX
BX
初始值
2000h
0
0
0
0
1
mov ax,6622h
2000h
3h
0
6622h
0
2
jmp 0ff0:0100
ff0h
100h
0
6622h
0
3
mov ax,2000h
ff0h
103h
0
2000h
0
4
mov ds,ax
ff0h
105h
2000h
2000h
0
5
mov ax,[8]
ff0h
108h
2000h
c389h
0
6
mov ax,[2]
ff0h
10bh
2000h
ea66h
0
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
这篇文章主要介绍了汇编语言存储及寄存器原理解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下字的存储一个16
CPU的工作原理是: 1、取指令:CPU的控制器从内存读取一条指令并放入指令寄存器。指令的格式一般是:操作码就是汇编语言里的mov,add,jmp等符号码;操
对于这个问题,汇编语言中用一下方法处理。(1)通过寄存器名指明要处理的数据的尺寸。例如:下面的指令中,寄存器指明了指令进行的是字操作:movax,1movbx,
汇编-JCC之前可以修改EIP寄存器的指令JMP,CALL,RETN所有JCC指令的动作->根据标志寄存器修改EIP的值标志寄存器EFLAGSCF(bit0)[
汇编语言汇编语言(assemblylanguage)是一种用于电子计算机、微处理器、微控制器或其他可编程器件的低级语言,亦称为符号语言。在汇编语言中,用助记符代