一、概念
每一个应用程序都会有自己独立的4GB内存空间。
但这进程上的4GB并不是真实的,真正需要读写时,进程的内存要映射到物理内存上。
二、内存地址
内存太大了,就不能给它起名字,所以就只能用编号。在读取或写入数据时,就用编号,这个编号就是内存地址(32位)。每一个编号对应的就是一个字节,也就是8位。
Q: 那这个4GB是怎么来的呢?
其实就是由编号是32位大小来的。也就是说其最大寻址范围位0XFFFFFFFF,每个寻址地址占1个字节,也就是8位,也即是说 (FFFFFFFF+1)*8转成10进制后就是4GB大小,所以最大寻址范围就是4GB,所以进程最大拥有自己的4GB内存。
三、内存的使用
①mov eax,1 要指明数据被存放的位置,以及存放的宽度,eax表示32位宽度,同时也指明了位置。
②mov byte ptr ds:[0018FFF0],1 表明将数字1以一个字节存到0018FFF0中,在其中既指定了字节数,又指定了内存位置。但是需要注意的是,要求内存地址在使用前必须是已经申请好了的。
在DTDebug中,右下角区域的内存地址就是申请好了的。
③mov dword ptr ds:[18FFFC],EAX
④mov eax,dword ptr ds:[18FFF8]
BYTE 一字节 WORD二字节
DWORD 四字节
DB DW DD表示在DTDebug左下角以一个字节、两个字节、四个字节三种形式查看内存。