汇编知识点-寄存器-2

数据寄存器(AX,BX,CX,DX 16位 和 EAX,EBX,ECX ,EDX 32位)
数据寄存器主要用来保存操作数和运算结果等信息,从而节省读取操作数所需占用总线和访问存储器的时间.32位CPU有4个32位的通用寄存器EAX,EBX,ECX,EDX.对低16位数据的存取,不会影响高16位的数据.这些低16位寄存器分别命名为:AX,BX,CX,DX.它和先前的16位CPU中的寄存器相一致/
4个16位寄存器又可分割成8个独立的8位寄存器(AX:AH-AL, BX:BH-BL, CX:CH-CL, DX:DH-DL ),每个寄存器都有自己的名称,可独立存取.程序员可利用数据寄存器的这种"可分可合"的特性,灵活地处理字/字节的信息.
寄存器AX和AL通常称为累加器(Accumulator),用累加器进行的操作可能需要更少时间.累加器可用于乘,除,输入/输出等操作,它们使用频率很高;
寄存器BX称为基地址寄存器(Base Register).它可作为存储器指针来使用;
寄存器CX称为计数寄存器(Count Register).在循环和字符串操作时,要用它来控制循环次数;在位操作中,当移多位时,要用CL来指明移位的位数;
寄存器DX称为数据寄存器(Data Register).在进行乘,除运算时,它可作为默认的操作数参与运算,也可用于存放I/O的端口地址.在16位CPU中,AX,BX,CX和DX不能作为基址和变址寄存器来存放存储单元的地址,但在32位CPU中,其32位寄存器EAX,EBX,ECX和EDX不仅可传送数据,暂存数据保存算术逻辑运算结果,而且也可作为指针寄存器,所以,这些32位寄存器更具有通用性.
变址寄存器(ESI和EDI)
32位CPU有2个32位通用寄存器ESI和EDI.其低16位对应先前CPU中的SI和DI,对低16位数据的存储,不影响高16位的数据.
寄存器ESI,EDI,SI和DI称为变址寄存器(Index Register),它们主要用于存放存储单元在段内的偏移量,用它们可实现多种存储器操作数的寻址方式,为以不同的地址形式访问存储器单元提供方便.变址寄存器不可分割成8位寄存器,作为通用寄存器,也可存储算术逻辑运算的操作数和运算结果.它们可作一般的存储器指针使用.在寄存器操作指令的指令的执行过程中,对它们有特定的要求,而且还具有特殊功能.
指针寄存器(EBP和ESP)
32位CPU有2个32位通用寄存器EBP和ESP.其低16位对应先前CPU中的BP和SP,对低16位数据的存取,不影响高16位数据.
寄存器EBP,ESP,BP和SP称为指针寄存器(Potnter Register),主要用于存放堆栈内存储单元的偏移量.用它们可实现多种存储器操作数的寻址方式,为以不同的地址形式访问存储单元提供方便.指针寄存器不可分割8位寄存器,作为通用寄存器,也可存储器算术逻辑运算的操作数和运算结果.
它们主要用于访问堆栈内的存储单元.并且规定:
BP为基地址(Base Pointer)寄存器,用它可直接存取堆栈中的数据,一般和BX用差不多;
SP位堆栈指针(Stack Pointer)寄存器.用它只可访问栈顶,偏移地址一般为SS:SP,SS放段地址,SP放偏移地址
指令指针存储器
指令指针EIP,IP(Instruction Pointer)是存放下次将要执行的指令在代码段的偏移量.在具有预取指令功能的系统中,下次要执行的指令通常已被预取到指令队列中.除非发生转移的情况,所以,在理解它们的功能时,不考虑存在指令队列的情况.

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值