脚本宝典收集整理的这篇文章主要介绍了内存中数据的存储与获取,脚本宝典觉得挺不错的,现在分享给大家,也给大家做个参考。
CPU 通过段地址和偏移地址获取内存中的数据, 根据寄存器的大小获取相应的字节数目: mov al,ds:[0]
ds 为段地址寄存器, [0] 表示偏移地址为 0 物理地址 = 段地址 * 0x10 + 偏移地址
从物理地址获取数据需要注意存储该数据寄存器的长度,下面将通过实例进行展示
2000:0
中的数据初始化,赋值为 "123456789A`ds
段地址寄存器赋值为 2000
: 用于寻找物理地址 2000:0
(0x20_000H)注意
ds
寄存器不能直接修改,需要通过数据寄存器间接修改
AX, BH, CL
中查看效果可以看到根据物理地址我们其实只能定位到两位 16 进制数,也就是 8 bit,也就是 1 字节数据,这个和 BH 或 CL 寄存器的长度是一致的,所以直接对应存储;但是 AX 是 16 位寄存器,也就是 2 字节的长度,这时就需要向高位寻找,用于填充 AX 的高位字节,所以 AX 的值是
{2000:[2]} {2000:[1]}
一个内存单元只能存储一字节的数据, 对于 Byte 来说只需要一个内存单元即可存放;
但对于 Word(=2Byte) 则需要两个连续的内存单元存放, 将高位字节存放到内存的高位地址, 低位字节存放到内存的低位地址中。用下面一个例子来实践一下
e 2000:0
修改目标内存单元的数据, 只能写入两位十六进制数, 也就是 8 位二进制数AX, BX, CX, DX 这些寄存器的大小都是一个字 (word=2Byte=16bit)
在这我们利用 AX
将两个字节的数据存储到内存单元中; 首先将 AX
寄存器赋值 1122
然后将 DS
寄存器(CPU默认用 DS
在内存寻址) 定位到 2000:0
, 现在的状态就是赋值前的初始状态:
不能直接修改
DS
寄存器, 需要借助A-DX
寄存器间接修改2000:0
处的内存状态:
DS
寄存器将 AX
寄存器中的内容放到内存单元 2000:0
中, 他会按照寄存器的大小, 自动分配相邻的两个内存单元, 如图所示, 11
是高位字节因此放到了内存的高位地址处;mov [0], ax
在这里
[0]
也就是[0000]
用于定义DS
的偏移地址, 合起来也就是2000:0000
的内存地址
以上是脚本宝典为你收集整理的内存中数据的存储与获取全部内容,希望文章能够帮你解决内存中数据的存储与获取所遇到的问题。
本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。