CPU还可分为:
32位CPU 8 16 32
64位CPU 8 16 32 64(增加了寻址能力)
# 32位的通用寄存器只有8个
# 可以在任意软件的底层看到
# 通用寄存器可以存储任何值
存值的范围:0~FFFFFFFF
计算机如何向寄存器中存值呢?对于二进制来说,直接在对应的内存地址修改值即可。
mov 存的地址 存的值
mov 存的地址1 存的地址2
mov指令:可以将数值写入寄存器;将寄存器中的数值写到寄存器
8个F 4个F 2个F # 1个F即4个1,1111
32位 16位 8位(L代表低8位,H代表高8位)
EAX AX AL
ECX CX CL
EDX DX DL
EBX BX BL
ESP SP AH
ENP NP CH
ESI SI DH
EDI DI BH
除了上述这些通用寄存器之外,计算机中还存在许多其他寄存器,每一位都有其相应的特定功能!
寄存器相对来说比较小,故需用到内存来存放数据。
每个应用程序都有4GB的内存空间,但实际上这只是一种“空头支票”的说法,程序在真正运行时才会用到物理内存。
1B = 8 bit
1 KB = 1024 B
1 MB = 1024 KB
1 GB = 1024 MB
所以4G的内存,最终计算为位可存储的最大容量约有三百多亿位的空间,即计算机中内存地址很多。
计算机中内存地址很多,空间很大,需要给每个空间分配一个地址,名字
上图所示给内存起的编号,就是所谓的内存地址。–> 由32位 即8个16进制的值构成
这里的32位代表了寻址能力!FFFFFFFF
数据宽度:byte word dword
地址位置:0xFFFFFFFF(注意并非任意地址都可以进行存值,只有程序申请过的内存地址才可以使用)
# 汇编如何向内存中写值
mov 数据宽度 内存地址, 1
mov byte ptr ds:[0x19FF70], 1
# 传递的值的大小一定要和数据宽度相等
此外,内存有多种写法。
ds:[0x19FF70+4] # 内存地址偏移
ds:[eax] # 寄存器
ds:[eax+4] # 寄存器偏移