Excel表格网

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

169 2024-02-28 09:42 admin   手机版

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

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。

二、汇编语言中SP寄存器是什么?

汇编语言中SP是堆栈寄存器。堆栈是一段按照后进先出原则组织起来的连续存储区域。用于程序保护或者恢复数据,或用于子程序调用及中断响应时保护与恢复现场。

SP是堆栈指针寄存器,存放着当前堆栈栈顶地址;

一般情况下,对SP有影响的指令,对SP的操作都是隐式的,即SP并不出现在指令操作数当中。要注意进出栈的匹配,否则将引起不可预期的后果。

三、汇编语言新手问题,基址寄存器和变址寄存器分别是干什么的?

位移量一般由立即数提供,可以使一个8位或16位的立即数。

偏移量指的是偏移地址。位移量是偏移量的一个组成部分。为了表示偏移地址的方便和灵活,偏移地址可以由几部分构成。基址寄存器+变址寄存器可以理解为: 基址寄存器中保存一个数组的起始地址,变址寄存器中保存某个数组元素与数组起始之间的相对偏移,加在一起,就是某个元素的偏移地址。

四、51单片机,汇编语言,中的R0寄存器,是个什么寄存器?和寄存器A,B等有啥区别啊?

R0是指寄存器组中的第一个寄存器,Register0。51单片机有4个可选的寄存器组。你需要好好看书了解一下这些基础知识啊。

五、在8086汇编语言中,哪些段寄存器可以用MOV指令赋值,哪些段寄存器不允许?

CS不可以直接赋值,这个段寄存器的值要由系统设置。

其他的DS、ES、SS都可以用MOV赋值,但不能用立即数。

六、汇编语言,DEC和INC后面的操作数必须是寄存器么?

不是的,还可以是内存地址

;INC、DEC 的指令格式:

;INC r/m

INC rmb ; FE /0 d0 d1 2~4 o---szap

INC rmw ; FF /0 d0 d1 2~4 o---szap

rmb

register or memory byte

rmw

register or memory word

七、在汇编语言中,8086,80x86有多少个寄存器?

主要是工作模式不同,指令集不同,寄存器不同,80x86有实模式(16位)和保护模式(32位),arm体系分为7中运行模式,用户模式和6中特权模式,总共37个寄存器,x86,51,arm7以及以前的版本都属于冯·诺依曼体系结构,arm9以后的版本都属于哈佛体系结构,运行效率更高,汇编语言的原理和编程思想都是一样的,首先要掌握处理器的体系结构,了解其工作过程,然后就可以编写汇编语言直接控制处理器处理数据以及控制外围设备

八、汇编语言中如何对寄存器清零,至少四中方法?

第一种:CIRA用清零指令第二种:MOVA,0FFH送零代码给寄存器第三种:SETBACPLA置一再取反(即位修正指令)

第四种:MULAB赋值A或B等于零,再用乘零指令第五种:Q1EQUR3R3或者Q1等于零。赋值指令

九、学汇编语言用什么软件?

取决于你的教材。

大部分教材都是使用MASM汇编器(比如王爽的《汇编语言》(强推)),MASM只能在Windows下使用。但是由于国内关于这个的教材众多,是入门的好选择。

如果你想要跨平台的话,NASM是很好的选择。使用NASM作为汇编器的书可看李忠的《x86汇编语言-从实模式到保护模式》。而且我看国外很多的项目都是使用NASM。你可以先用MASM入门,然后转到NASM。

不过还是先找本书看吧,汇编器的学习都差不多,一个学会了其他的也都差不多。

十、汇编语言前景

汇编语言前景:过去、现在和未来

汇编语言是一种低级的计算机编程语言,与机器码相对应。尽管它在现代计算机科学领域中已经有了相对较少的应用,但它在过去的几十年里一直发挥着重要作用。本文将探讨汇编语言的过去、现在和未来,以及它在当前技术环境中的前景。

过去

在计算机的早期阶段,汇编语言是唯一可用的编程语言之一。计算机程序员必须直接编写机器码指令,以便让计算机执行特定任务。然而,随着高级编程语言的出现,汇编语言逐渐被淘汰。

尽管如此,汇编语言在过去发挥着重要的作用。它可以直接访问计算机硬件,并具有高度的控制力。在计算机游戏开发、嵌入式系统设计和操作系统内核开发等领域,汇编语言曾是首选语言。它能够优化代码,实现更高效的计算和更有效的内存利用。

然而,随着计算机体系结构和编程语言的发展,汇编语言开始减少其在实际项目中的应用。高级编程语言的出现使得开发人员能够更快速地实现复杂功能,并提高开发效率。此外,汇编语言的学习曲线更为陡峭,对于非专业程序员来说相对困难。

现在

在现代计算机科学领域中,汇编语言的应用范围有限,但仍然存在一些特定的用例。

首先,嵌入式系统开发是一个非常适合使用汇编语言的领域。嵌入式系统通常有严格的资源限制,汇编语言可以直接控制硬件,实现最佳的性能和资源利用。此外,对于某些特殊的嵌入式平台,只能使用汇编语言进行开发。

其次,在漏洞和反汇编等领域,汇编语言仍然是必须掌握的技能。黑客和安全专家经常需要分析底层代码,以发现漏洞并进行安全评估。通过了解汇编语言,他们能够更好地理解程序的执行过程,从而提供更有效的保护措施。

此外,对于对计算机体系结构和底层操作有浓厚兴趣的计算机科学学生和研究人员来说,学习汇编语言仍然具有重要意义。它可以帮助他们深入了解计算机内部的工作原理,并对其他高级编程语言有更深刻的理解。

未来

尽管汇编语言在现代技术环境中的应用范围相对较小,但它在未来仍然有一定的前景。

首先,随着物联网和嵌入式系统的普及,对小型、低功耗设备的需求不断增加。在这些设备中,优化的代码和高效的资源利用至关重要。汇编语言可以提供对硬件的直接控制,满足这些需求。

其次,人工智能和机器学习等领域的发展可能为汇编语言带来新的机会。虽然高级编程语言如Python和R在这些领域中更为普遍,但对于一些特定的优化任务,汇编语言可能提供更快速和高效的解决方案。

此外,虽然学习和掌握汇编语言相对困难,但对于个别计算机科学学生和研究人员来说,它仍然是一项重要的专业技能。深入了解计算机内部工作原理并能够直接控制硬件的能力,将成为未来计算机科学领域中的重要竞争优势。

结论

汇编语言在计算机科学的发展历程中起到了重要的作用。尽管它在现代技术环境中的应用范围相对较小,但在一些特定的领域和特定的用例中仍然具有价值。嵌入式系统开发、漏洞分析和对计算机内部工作原理的深入理解都是汇编语言的重要应用领域。

尽管如今高级编程语言的流行,但汇编语言的学习仍然具有一定的意义。它可以帮助开发人员更好地理解计算机底层的运行机制,并为一些特定的优化任务提供高效的解决方案。对于计算机科学学生和研究人员来说,掌握汇编语言依然是一项重要的专业技能。

在未来,随着物联网和嵌入式系统的发展,以及人工智能和机器学习等领域的进一步演进,汇编语言可能会找到新的应用机会。它具备直接控制硬件的能力,为某些特定的优化任务提供了可能性。

顶一下
(0)
0%
踩一下
(0)
0%
相关评论
我要评论
用户名: 验证码:点击我更换图片
上一篇:返回栏目