逆向-内存

一、寄存器与内存的区别:

1、寄存器位于CPU内部,执行速度快,但比较贵。

2、内存速度相对较慢,但成本较低,所以可以做的很大。

3、寄存器和内存没有本质区别,都是用于存储数据的容器,都是定宽的。

4、寄存器常用的有8个:EAX、ECX、EDX、EBX、ESP、EBP、ESI、EDI。

5、计算机中的几个常用计量单位:BYTE WORD DWORD

 BYTE 字节 = 8(BIT)

WORD  字    =   16(BIT)

DWORD 双字  =   32(BIT)

1KB = 1024 BYTE

1MB = 1024 KB 

1GB = 1024 MB

6、内存的数量特别庞大,无法每个内存单元都起一个名字,所以用编号来代替,我们称计算机CPU是32位或者64位,主要指的就是内存编号的宽度,而不是寄存器的宽度。 有很多书上说之所以叫32位计算机是因为寄存器的宽度是32位,是不准确的,因为还有很多寄存器是大于32位的。

 计算机内存的每一个字节会有一个编号(即内存编号的单位是字节),如下图:

 

 32位计算机的编号最大是32位,也就是32个1 换成16进制为FFFFFFFF,也就是说,32位计算机内存寻址的最大范围是FFFFFFFF+1 

内存的单位是字节,那内存中能存储的信息最多为:FFFFFFFF+1 字节  即4G,这也是为什么我们在一个XP的系统上面如果物理内存超过4G是没有意义的原因。

7、只要是32位的计算机,那么最多识别的内存为4G,对吗?

 

 去网上搜索答案,大部分都会甩给一个公式

2^32 = 4GB

我当时看到这个公式的时候,没太在意,后来我自己换算了一下,发现和我理解的不一样,我换算出来后不是4G而是512M也就是0.5G。

32位就可以表示有2的32次种情况,就表示可以指向232 个地址,而最大的数字就表示可以访问的内存最大的容量,再大了,由于地址表示不了,所以就无法使用了。所以我就按下面方法进行了换算:

232 bit = 229 byte = 219 KB = 29 MB = 2-1 GB = 0.5 GB

这样一算就是32位最大只能寻址的范围就是 0.5GB啊 怎么算出是4GB呢?

内存是计算机系统的主存储器。
而CPU计算的时候不能直接访问硬盘的数据,但是可以直接访问内存的里的数据。

内存也是存储介质,内存里存放的数据其实也是只是存放0或者1这两个二进制数字,所以可以内存里有海量的小格子,每1个格子是1个bit,小格子里面就只能存放0或1。
那么如果要表示数值255需要几个格子来放呢?
根据二级制算法就是用8个格子,每个格子都是1,来表示255.
计算机规定8bit=1byte 就是1字节=8位。

内存的大小就根据格子的多少来进行计算的。

例如一个4GB的内存到底有多少格子呢?
那就将4GB转换为bit就可以了
4GB = 22 GB = 212 MB = 222 KB = 232 byte = 235 bit

也就是4GB的内存有 235 个格子。

如果每一个格子一个地址的话?那么要想全部都访问4GB的内存就需要 35位,32位是不够的。

那么32位操作系统是怎么做到可以访问4GB内存的呢?

**实际上内存是把8个bit排成1组, 每1组成为1个单位, 大小是1byte(字节), cpu每一次只能访问1个byte, 而不能单独去访问具体的1个小格子(bit). 1个byte字节就是内存的最小的IO单位.**

既然内存的最小IO单位是字节byte,那么我们其实不需要为每一个格子也就是每一bit去分配地址了,而是按照8个bit为一组,也就是一个字节分配一个地址。

其实计算机操作系统会给内存每1个字节分配1个内存地址, cpu只需要知道某个数据类型的地址, 就可以直接去到读影的内存位置去提取数据了。

明白了上面的道理,
我们再算一下,其实32位表示 232 个地址,而每一个地址是指向的是 8bit为一组的 byte ,所以要算到寻址的话,就要在乘以8 ,也就是 235 个bit,这样再换算为GB就是 4GB了。

到此终于明白了4GB是怎么算出来的了,原来 “32位操作系统” 中的“位”并不是 内存中的“bit”的概念,对应到内存中其实是“字节byte”,所以才有了 232 = 4GB 的说明法

二、内存格式

 

 1、每个内存单元的宽度为8

2、[编号]称为地址

3、地址的作用:当我们想从内存中读取数据或者想向内存中写入数据,首先应该找到要读、写的位置。就像写信要写地址一样。

三、从指定内存中写入/读取数据

mov dword ptr ds:[0x0012FF34],0x12345678

mov eax,dword ptr ds:[0x0012FF34]

dword :要读/写多少  此时是4字节   byte == 1字节  word == 2字节

ptr: Point 代表后面是一个指针 (指针的意思就是里面存的不是普通的值,而是个地址)

ds:段寄存器 先不用管 记住就行

0x0012FF34:内存编号,必须是32位的  前面0可以省略

注意:地址编号不要随便写,因为内存是有保护的,并不是所有的内存都可以直接读写(需要特别处理)

建议地址编号写成esp的值

 

 

 

 

 

 

 

 

 

posted @ 2023-01-06 20:17  Mast丶轩  阅读(176)  评论(0)    收藏  举报