汇编语言寄存器都叫什么? 汇编语言寄存器?

\u6c47\u7f16\u8bed\u8a00\u5bc4\u5b58\u5668\u90fd\u53eb\u4ec0\u4e48

8086\u7684\u8bdd
\u6709\u901a\u7528\u5bc4\u5b58\u5668\uff0c\u6bb5\u5bc4\u5b58\u5668\uff0c\u6807\u5fd7\u5bc4\u5b58\u5668\uff01

\u901a\u7528\u5bc4\u5b58\u5668\u5206
\u6570\u636e\u5bc4\u5b58\u5668AX.BX.CX.DX\uff1b\u6307\u9488\u5bc4\u5b58\u5668(SP\u5806\u6808\u6307\u9488\u5bc4\u5b58\u5668\uff0cBP\u5806\u6808\u57fa\u5740\u6307\u9488\u5bc4\u5b58\u5668)\u548c\u53d8\u5740\u5bc4\u5b58\u5668\uff08SI\u6e90\u53d8\u5740\u5bc4\u5b58\u5668\uff0cDI\u76ee\u7684\u53d8\u5740\u5bc4\u5b58\u5668\uff09.

\u6bb5\u5bc4\u5b58\u5668\uff1a
CS\u4ee3\u7801\u6bb5\uff0cSS\u5806\u6808\u6bb5\uff0cDS\u6570\u636e\u6bb5\uff0cES\u9644\u52a0\u6bb5

\u6807\u5fd7\u5bc4\u5b58\u5668\uff1aF
\u624b\u673a\u6253\u7684\uff01\u5e0c\u671b\u91c7\u7eb3\uff01

\u5b9a\u4e49\u662f\u7edd\u5bf9\u7684

1、寄存器

32位寄存器有16个,分别是:

4个数据寄存器(EAX、EBX、ECX、EDX)。

2个变址和指针寄存器(ESI和EDI);2个指针寄存器(ESP和EBP)。

6个段寄存器(ES、CS、SS、DS、FS、GS)。

1个指令指针寄存器(EIP);1个标志寄存器(EFlags)。


2、数据寄存器

数据寄存器主要用来保存操作数和运算结果等信息,从而节省读取操作数所需占用总线和访问存储器的时间。

32位CPU有4个32位通用寄存器:EAX、EBX、ECX和EDX。对低16位数据的取存,不会影响高16

位的数据,这些低16位寄存器分别命名为AX、BX、CX和DX,它和先前的CPU中的寄存器相一致。

4个16位寄存器又可分割成8个独立的8位寄存器(AX:ah~al、BX:bh~bl、CX:ch~cl:DX:dh~dl)。

每个寄存器都有自己的名称,可独立存取。程序员可利用数据寄存器的这种“可合可分”的特性,灵活地处理字/

字节的信息。

AX和al通常称为累加器,用累加器进行的操作可能需要更少时间,累加器可用于乘、除、输入/输出等操作,

它们的使用频率很高。

BX称为基地址寄存器,它可作为存储器指针来使用。

CX称为计数寄存器,在循环和字符串操作时,要用它来控制循环次数;在位操作中,当移多位时,要用cl来

指明位移的位数。

DX称为数据寄存器,在进行乘、除运算时,它可以为默认的操作数参与运算,也可用于存放I/O的端口地址。

在16位CPU中,AX、BX、CX和DX不能作为基址和变址寄存器来存放存储单元的地址,但在32位CPU

中,其32位寄存器EAX、EBX、ECX和EDX不仅可传送数据、暂存数据、保存算术逻辑运算结果,而且也可

作为指针寄存器,所以,这些32位寄存器更具有通用性。


3、变址寄存器

32位CPU有2个32位通用寄存器ESI和EDI,其低16位对应先前CPU中的SI和DI,对低16位数据的

存取,不影响高16位的数据。

ESI、EDI、SI和DI称为变址寄存器,它们主要用于存放存储单元在段内的偏移量,用它们可实现多种存储器

操作数的寻址方式,为以不同的地址形式访问存储单元提供方便。

变址寄存器不可分割成8位寄存器,作为通用寄存器,也可存储算术逻辑运算的操作数和运算结果。

它们可作一般的存储器指针使用,在字符串操作指令的执行过程中,对它们有特定的要求,而且还具有特殊的

功能。


4、指针寄存器

32位CPU有2个32位通用寄存器EBP和ESP,其低16位对应先前CPU中的BP和SP,对低16位数

据的存取,不影响高16位的数据。

EBP、ESP、BP和SP称为指针寄存器,主要用于存放堆栈内存储单元的偏移量,用它们可实现多种存储器

操作数的寻址方式,为以不同的地址形式访问存储单元提供方便。

指针寄存器不可分割成8位寄存器,作为通用寄存器,也可存储算术逻辑运算的操作数和运算结果。

它们主要用于访问堆栈内的存储单元,并且规定:

BP为基指针寄存器,用它可直接存取堆栈中的数据。

SP为堆栈指针寄存器,用它只可访问栈顶。


5、段寄存器

段寄存器是根据内存分段的管理模式而设置的。内存单元的物理地址由段寄存器的值和一个偏移量组合而成

的,这样可用两个较少位数的值组合成一个可访问较大物理空间的内存地址。

32位CPU有6个段寄存器,分别如下:

CS:代码段寄存器    ES:附加段寄存器

DS:数据段寄存器    FS:附加段寄存器

SS:堆栈段寄存器    GS:附件段寄存器

在16位CPU系统中,只有4个段寄存器,所以,程序在任何时刻至多有4个正在使用的段可直接访问,在

32位微机系统中,它有6个段寄存器,所以在此环境下开发的程序最多可同时访问6个段。

32位CPU有两个不同的工作方式:实方式和保护方式。在每种方式下,段寄存器的作用是不同的,有关规定

简单描述如下:

实方式:段寄存器CS、DS、ES和SS与先前CPU中的所对应的段寄存器的含义完全一致,内存单元的逻辑

地址仍为“段地址:偏移地址”的形式,为访问某内存段内的数据,必须使用该段寄存器和存储单元的偏移地址。

保护方式:在此方式下,情况要复杂得多,装入段寄存器的不再是段值,而是称为“选择子”的某个值。


6、指令指针寄存器


32位CPU把指令指针扩展到32位,并记作EIP,EIP的低16位与先前CPU中的IP作用相同。

指令指针EIP、IP是存放下次将要执行的指令在代码段的偏移地址,在具有预取指令功能的系统中,下次要执

行的指令通常已被预取到指令队列中,除非发生转移情况,所以,在理解它们的功能时不考虑存在指令队列的情

况。

在实方式下,由于每个段的最大范围为64KB,所以,EIP的高16位肯定都为0,此时,相当于只用其低16

位的IP来反映程序中的指令的执行次序。


7、标志寄存器

1.运算结果标志位。一共6个,包括:CF进位标志位、PF奇偶标志位、AF辅助进位标志位、ZF零标志位、

SF符号标志位、OF溢出标志位。

2.状态控制标志位。一共3个,包括:TF追踪标志位、IF中断允许标志位、DF方向标志位。

以上标志位在第7章里都讲过了,在这里就不再解释了,现在讲讲32位标志寄存器增加的4个标志位。

1. I/O特权标志IOPL。

IOPL用两位二进制位来表示,也称为I/O特权级字段,该字段指定了要求执行I/O指令的特权级,如果当前

的特权级别在数值上小于等于IOPL的值,那么,该I/O指令可执行,否则将发生一个保护异常。

2. 嵌套任务标志NT。

NT用来控制中断返回指令IRET的执行。具体规定如下:

(1)     当NT=0,用堆栈中保存的值恢复EFlags、CS和EIP,执行常规的中断返回操作。

(2)     当NT=1,通过任务转换实现中断返回。

3. 重启动标志RF。

RF用来控制是否接受调试故障。规定:RF=0时,表示接受,否则拒绝。

4. 虚拟8086方式标志VM。

如果VM=1,表示处理机处于虚拟的8086方式下的工作状态,否则,处理机处于一般保护方式下的工作状态。


8、32位地址的寻址方式

最后说一下32位地址的寻址方式。在前面我们学习了16位地址的寻址方式,一共有5种,在32位微机系统

中,又提供了一种更灵活、方便但也更复杂的内存寻址方式,从而使内存地址的寻址范围得到了进一步扩大。

在用16位寄存器来访问存储单元时,只能使用基地址寄存器(BX和BP)和变址寄存器(SI和DI)来作为

偏移地址的一部分,但在用32位寄存器寻址时,不存在上述限制,所有32位寄存器(EAX、EBX、ECX、

EDX、ESI、EDI、EBP、和ESP)都可以是偏移地址的一个组成部分。

当用32位地址偏移量进行寻址时,偏移地址可分为3部分:

1. 一个32位基址寄存器(EAX、EBX、ECX、EDX、ESI、EDI、EBP、ESP)。

2. 一个可乘以1、2、4、8的32位变址寄存器(EAX、EBX、ECX、EDX、ESI、EDI和EBP)。

3. 一个8位~32位的偏移常量。

比如,指令:mov ebx, [eax+edx*2+300]

Eax就是基址寄存器,edx就是变址寄存器,300H就是偏移常量。

上面那3部分可进行任意组合,省去其中之一或之二。

下面列举几个32位地址寻址指令:

Mov ax, [123456]

Mov eax, [ebx]

Mov ebx, [ecx*2]

Mov ebx, [eax+100]

Mov ebx, [eax*4+200]

Mov ebx, [eax+edx*2]

Mov ebx, [eax+edx*4+300]

Mov ax, [esp]

由于32位寻址方式能使用所有的通用寄存器,所以,和该有效地址相组合的段寄存器也就有新的规定,具体

规定如下:

1. 地址中寄存器的书写顺序决定该寄存器是基址寄存器还是变址寄存器。

如:[ebx+ebp]中的ebx是基址寄存器,ebp是变址寄存器,而[ebp+ebx]中的ebp是基址寄存器,ebx是变

址寄存器,可以看出,左边那个是基址寄存器,另一个是变址寄存器。

2. 默认段寄存器的选用取决于基址寄存器。

3. 基址寄存器是ebp或esp时,默认的段寄存器是SS,否则,默认的段寄存器是DS。

4. 在指令中,如果显式地给出段寄存器,那么显式段寄存器优先。

下面列举几个32位地址寻址指令及其内存操作数的段寄存器。

指令列举:          访问内存单元所用的段寄存器

mov ax, [123456]    ;默认段寄存器为DS。

mov ax, [ebx+ebp]    ;默认段寄存器为DS。

mov ebx, [ebp+ebx]    ;默认段寄存器为SS。

mov ebx, [eax+100]    ;默认段寄存器为DS。

mov edx, ES:[eax*4+200]    ;显式段寄存器为ES。

mov [esp+edx*2], ax    ;默认段寄存器为SS。

mov ebx, GS:[eax+edx*8+300]    ;显式段寄存器为GS。

mov ax, [esp]    ;默认段寄存器为SS。



楼主说的应该是8086,你可以百度文库,我这有这个
8086的话
有通用寄存器,段寄存器,标志寄存器!

通用寄存器分
数据寄存器AX.BX.CX.DX;指针寄存器(SP堆栈指针寄存器,BP堆栈基址指针寄存器)和变址寄存器(SI源变址寄存器,DI目的变址寄存器).

段寄存器:
CS代码段,SS堆栈段,DS数据段,ES附加段

寄存器按照功能的不同分别叫做通用寄存器(AX,BX,CX,DX,SP,BP,SI,DI。其中的前四个寄存器可分别分成AH,AL ;BH,BL;CH,CL;DH,DL的八位寄存器)、指令指针寄存器(IP)、标志寄存器(FLAGS)、段寄存器(CS,DS,ES,SS)。它们的区别和联系体现在它们的功能上,对它们的深入了解和正确运用需要通过编写程序来实现。



对于8086的系统:
1.寄存器按照功能的不同可分为通用寄存器(AX,BX,CX,DX,SP,BP,SI,DI。其中的前四个寄存器可分别分成AH,AL ;BH,BL;CH,CL;DH,DL的八位寄存器)、指令指针寄存器(IP)、标志寄存器(FLAGS)、段寄存器(CS,DS,ES,SS)。它们的区别和联系体现在它们的功能上,对它们的深入了解和正确运用需要通过编写程序来实现。
2.大致功能如下:
AX,可存放一般数据,而且可作为累加器使用;
BX,可存放一般数据,而且可用来存放数据的指针(偏移地址),常常和DS寄存器连用;
CX,可存放一般数据,而且可用来做计数器,常常将循环次数用它来存放;
DX,可存放一般数据,而且可用来存放乘法运算产生的部分积,或用来存放输入输出的端口地址(指针);
SP,用于寻址一个称为堆栈的存储区,通过它来访问堆栈数据;
BP,可存放一般数据,用来存放访问堆栈段的一个数据区,作为基地址;
SI,可存放一般数据,还可用于串操作中,存放源地址,对一串数据访问;
DI,可存放一般数据,还可用于串操作中,存放目的地址,对一串数据访问;
IP,用于寻址当前需要取出的指令字节,程序员不能对它直接操作;
FLAGS,用于指示微处理器的状态并控制它的操作;
CS,代码段寄存器,代码段是一个存储区域,存放的是CPU要使用的代码,CS存放代码段的段基地址;
DS,数据段寄存器,数据段是包含程序使用的大部分数据的存储区,DS中存放数据段的段基地址;
ES,附加段寄存器,附加段是为某些串操作指令存放目的操作数而附近的一个数据段,ES中存放该数据段的段基地址;
SS,堆栈段寄存器,堆栈段是内存中一个特殊的存储区,用于暂时存放程序运行时所需的数据或地址信息。SS中存放该存储区的段基地址。

  • 姹囩紪璇█涓浠涔鏄熀鍧鍙樺潃瀵勫瓨鍣?
    绛旓細鍩哄潃瀵勫瓨鍣細瀵勫瓨鍣BX绉颁负鍩哄湴鍧瀵勫瓨鍣(Base Register)锛屽畠鍙綔涓哄瓨鍌ㄥ櫒鎸囬拡鏉ヤ娇鐢ㄣ傚彉鍧瀵勫瓨鍣細32浣岰PU鏈2涓32浣嶉氱敤瀵勫瓨鍣‥SI鍜孍DI銆傚叾浣16浣嶅搴斿厛鍓岰PU涓殑SI鍜孌I锛屽浣16浣嶆暟鎹殑瀛樺彇锛屼笉褰卞搷楂16浣嶇殑鏁版嵁銆傚瘎瀛樺櫒ESI銆丒DI銆丼I鍜孌I绉颁负鍙樺潃瀵勫瓨鍣(Index Register)锛屽畠浠富瑕佺敤浜庡瓨鏀惧瓨鍌ㄥ崟鍏冨湪娈...
  • 姹囩紪璇█涓 cs,ds,ss,es鍒嗗埆鏄偅浜涜嫳鏂囧崟璇嶇殑缂╁啓?
    绛旓細瀵勫瓨鍣閫氬父閮界敤鏉ユ剰鎸囩敱涓涓寚浠や箣杈撳嚭鎴栬緭鍏ュ彲浠ョ洿鎺ョ储寮曞埌鐨勬殏瀛樺櫒缇ょ粍銆傛洿閫傚綋鐨勬槸绉颁粬浠负 鈥滄灦鏋勫瘎瀛樺櫒鈥濄備緥濡傦紝x86 鎸囦护鍙婂畾涔夊叓涓 32 浣嶅厓瀵勫瓨鍣ㄧ殑闆嗗悎锛屼絾涓涓疄浣 x86 鎸囦护闆嗙殑 CPU 鍙互鍖呭惈姣斿叓涓洿澶氱殑瀵勫瓨鍣ㄣ傚瘎瀛樺櫒鏄疌PU鍐呴儴鐨勫厓浠讹紝瀵勫瓨鍣ㄦ嫢鏈夐潪甯搁珮鐨勮鍐欓熷害锛屾墍浠ュ湪瀵勫瓨鍣ㄤ箣闂寸殑鏁版嵁...
  • 鍦姹囩紪璇█涓,CPU涓殑瀵勫瓨鍣鍜岀紦瀛鏄粈涔,浠栦滑鐨勫叧绯绘槸浠涔堟牱鐨?
    绛旓細CPU涓殑瀵勫瓨鍣鍒嗕负濂藉绫诲惂锛佹瘮濡傞氱敤瀵勫瓨鍣紝CS锛孌S锛孲S绛夌瓑锛岃繕鏈塈P杩欎簺涓撶敤瀵勫瓨鍣紝鍚勬湁鍚勭殑鐢ㄥ鍟婏紒CPU涓殑缂撳瓨鏄敤鏉ユ彁楂樿绠楁満杩愯閫熷害鐨勶紒瀵勫瓨鍣ㄦ槸蹇呴』鐨勮岀紦瀛樻湁澶у皬涔嬪垎锛岃秺澶ч熷害瓒婂揩锛
  • 姹囩紪璇█涓瀵勫瓨鍣AL鏈浠涔浣滅敤?
    绛旓細姹囩紪璇█涓瀵勫瓨鍣AX鍜孉L閫氬父绉颁负绱姞鍣(Accumulator)锛岀敤绱姞鍣ㄨ繘琛岀殑鎿嶄綔鍙兘闇瑕佹洿灏戞椂闂淬傜疮鍔犲櫒浣滅敤锛氱敤浜庝箻銆侀櫎銆佽緭鍏/杈撳嚭绛夋搷浣滐紝浣跨敤棰戠巼寰堥珮銆
  • 姹囩紪璇█瀵勫瓨鍣瀛樺偍鍣ㄩ棶棰
    绛旓細閫氱敤瀵勫瓨鍣8涓細AX BX CX DX SP BP DI SI 鍔犳柟鎷彿灏辨槸瀛樺偍鍣紝瀛樺偍鍣ㄤ箣闂翠笉鑳戒紶閫掓暟鎹 REG瀵勫瓨鍣 MEM鍌ㄥ瓨鍣 SREG鐘舵佸瘎瀛樺櫒 绔嬪嵆鏁版湁瀹藉害锛屼絾瑕佺湅鎬庝箞鐢細mov ax,12h灏辨槸16浣嶇殑锛宮ov al,12h灏辨槸8浣嶇殑锛屼絾涓嶈兘mov al,0012h
  • 姹囩紪璇█涓璍EA,AX,AL,BX绛夌瓑浠涔鎰忔
    绛旓細杩欏嚑涓姹囩紪璇█LEA锛堢敱缂栬瘧鍣ㄨ绠楀嚭data鍙橀噺鐨勫湴鍧锛岀劧鍚庢浛鎹㈡帀鎸囦护涓嚭鐜癲ata鍙橀噺鏍囪瘑 锛 AX,AL(CPU鐨16浣嶆暟鎹瘎瀛樺櫒AX锛岃繍绠楁椂灏嗘搷浣滄暟浠庡唴瀛樺彇鍑烘斁鍏ュ瘎瀛樺櫒杩涜璁$畻AX淇濆瓨16浣2杩涘埗鏁 AX涔熷彲鍒嗕负涓や釜8浣嶅瘎瀛樺櫒 AH,AL 鍒嗗埆涓洪珮8浣嶅拰浣8浣)鍗虫妸AL鐨勫亸绉诲湴鍧閫佸叆AX瀵勫瓨鍣紝BX锛孊L锛孌I閮芥槸瀵勫瓨鍣锛...
  • 姹囩紪璇█涓墍鏈瀵勫瓨鍣鐨勪綔鐢
    绛旓細涓嬮潰缁欎綘閫氱敤瀵勫瓨鍣鍑犱釜渚嬪瓙锛氬亣濡俥ax鐨勫间负10锛岃灏嗕竴鍧楀唴瀛樿祴鍊间负cc锛屽惊鐜10娆★紝鑰孍DI閲岄潰鏄唴瀛樺湴鍧鐨勮瘽锛岄偅涔堜唬鐮佸氨鏄細mov EAX,0Xcc mov ecx锛0xa rep stos byte ptr [edi]杩欐牱锛屽唴瀛樺氨鍏ㄩ儴琚垚涓衡渃cccccccccccccccc鈥,杩欐牱鐨勪唬鐮佸埌澶勯兘鏄紝灏ゅ叾娌℃湁鍒濆鍖栦箣鍚庯紝灏辫兘瑙佸埌杩欐牱鐨凜C锛屼腑鏂囨樉绀...
  • 鐪嬬帇鐖界殑姹囩紪璇█,涓婅竟璇8086CPU瀵勫瓨鍣鐨勫悕瀛浠涔鐨,鐜板湪鐢ㄧ殑cpu涓嶄竴鏍...
    绛旓細涓変釜鎸囬拡瀵勫瓨鍣锛圔P銆両P銆丼P锛夈佷竴涓爣蹇楀瘎瀛樺櫒锛團lag锛夈傚湪鍚庢湡鐨凜PU涓紝涓轰簡淇濊瘉涓8086鍏煎锛岃繖浜涘瘎瀛樺櫒涓嶅彉锛屼絾鏂板浜嗕竴浜涘瘎瀛樺櫒銆傚洜姝わ紝8086姹囩紪璇█鍦ㄥ悗鏈烠PU瀹炴ā寮忕姸鎬佷笅閮藉彲浠ョ紪璇戦氳繃銆傚洜姝わ紝鍒濆鑰呭線寰鐢ㄦ渶绠鍗曠殑瀹炰緥瀛︿範姹囩紪璇█锛岃鐢ㄥ埌8086.椹摀婢у啿鎶掗獮鐤嗗挨搴︿氦鍗囪儱娼滅鐞呮湰鑻ユ⒌鑺婂穮娼 ...
  • 姹囩紪璇█涓, DATA銆 STACK銆 TOP銆 SP鏄粈涔鎰忔
    绛旓細2銆佺悊瑙ATA锛孲TACK锛孴OP鍙傛暟鍚箟 缁撳悎绋嬪簭甯告湁鐨勪吉浠g爜鍐呭鍙互鍙戠幇DATA锛孲TACK涓変釜鍙傛暟涓嶥S锛孲S涓変釜瀵勫瓨鍣涓涓瀵瑰簲锛屼笁涓弬鏁扮粨鍚姹囩紪绋嬪簭缂栧啓鍙互缈昏瘧涓烘暟鎹拰鍫嗘爤銆3銆佺患鍚堢悊瑙f暣娈典唬鐮 缁撳悎浠ヤ笂鍐呭鍙互澶ц嚧鐞嗚В璇ヤ唬鐮佺敤浜庡疄鐜颁吉浠g爜鐨勯儴鍒嗘槧灏勶紝鍗虫暟鎹尯鍜屽爢鏍堝尯涓庡瘎瀛樺櫒鐨勬槧灏勩備互8086缁撴瀯涓轰緥浜嗚В杩欏嚑...
  • 姹囩紪璇█瀵勫瓨鍣?
    绛旓細瀹氫箟鏄粷瀵圭殑
  • 扩展阅读:汇编语言寄存器有哪些 ... 汇编段寄存器有哪些 ... 下列寄存器 ... 寄存器的三种类型 ... 寄存器地址对照表 ... 汇编语言寄存器详解 ... 汇编语言程序员可见的是 ... python编程代码 ... 基址寄存器程序员可见吗 ...

    本站交流只代表网友个人观点,与本站立场无关
    欢迎反馈与建议,请联系电邮
    2024© 车视网