汇编语言中常用的寄存器

2024-08-23 11:20

本文主要是介绍汇编语言中常用的寄存器,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一、寄存器的分类

寄存器是计算机硬件中的一个小型存储区域,它位于中央处理单元(CPU)内部,用于临时存储数据和指令。寄存器的访问速度非常快,通常比内存中的数据访问速度快得多。寄存器是CPU执行指令时最常使用的存储器,因为它们提供了快速的数据处理和指令执行的能力。
寄存器可以分为以下几类:


1. 通用寄存器:用于存储数据和地址,最常用的寄存器——AX、BX、CX、DX

        AX是累加器,用累加进行其它逻辑运算或操作,节约时间

        BX是基地址寄存器,作为存储器指针来使用,在内存寻址的时候存放基地址

        CX是计数寄存器,用于循环和迭代操作,在循环中用于保存循环次数,并在迭代后递减

        DX是数据寄存器,用于保存数据和计算结果的临时存储

2.变址寄存器:在某个地址的基础上进行偏——SI、DI

一般将SI与DS段寄存器联用,用来确定源操作数的地址,DI与ES段寄存器联用,用来确定目的操作数的地址。

        SI是源变址寄存器

        DI是目的变址寄存器

3.指针寄存器:存储指针——SP、BP

        SP是堆栈寄存器,存放栈顶指针的位置

        BP是基址指针寄存器,存放栈底指针,用来寻找栈内的元素

4.专用寄存器——指令寄存器、标志寄存器

        指令寄存器IP:存放下一个CPU指令存放的内存地址

        标志寄存器EFLAGS:存储一些标志位


5. 段寄存器:存储选择子——CS、DS、SS、ES

        在x86架构中,段寄存器包括CS(代码段)、DS(数据段)、ES(附加段)、SS(堆栈段)。

        CS:存放正在运行的程序代码所在段的段基址,表示当前所使用的指令代码可以从该段寄存器指定的存储器中获得,相应的偏移量由IP提供。这样就可以找到下一条指令。

        DS:指出当前程序使用的数据所存放段的最低地址,即存放数据段的段基址,

        SS:指出当前堆栈的底部地址,即存放堆栈段的基地址。

        ES:指出当前程序使用附加数据段的段基址,该段是串操作指令中目的串所在的段。

 二、段寄存器&&段选择子&&段描述符

1、段寄存器

段寄存器的数据结构如下:

Struct SegMent{
WORD	Selector段选择子;//16位selector
WORD	Attribute;//16位的Attribute
DWORD	Base;//32位的Base
DWORD	Limit	//32位的Limit
};

 段寄存器结构图:

 

段寄存器分为可见部分和不可见部分,可见部分是选择子,不可见部分是后来根据段描述符的内容填充的,所以说段寄存器读的是16位,写一个寄存器要96位。

2、段选择子

是一个16位的整数,位于段寄存器中,是段寄存器的16位可见部分,段选择子分为三部分:

其中,0-1位是RPL(特权等级,请求特权级),第2位是TI位,3-15位是索引Index位。 段选择子不直接指向内存的段,而是指向段定义的段描述符。将Index乘以段描述符的字节数(通常是8字节)+GDT/LDT的基址就可以定位到段描述符。(GDT/LDT的基址存在于寄存器中)

3、段描述符

段描述符常为8字节(64位)为一组 ,分为高4字节和低4字节,结构图如下:

 基地址域:有三个基地址组合而成,共32位

这篇关于汇编语言中常用的寄存器的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1099236

相关文章

Java String字符串的常用使用方法

《JavaString字符串的常用使用方法》String是JDK提供的一个类,是引用类型,并不是基本的数据类型,String用于字符串操作,在之前学习c语言的时候,对于一些字符串,会初始化字符数组表... 目录一、什么是String二、如何定义一个String1. 用双引号定义2. 通过构造函数定义三、St

Linux上设置Ollama服务配置(常用环境变量)

《Linux上设置Ollama服务配置(常用环境变量)》本文主要介绍了Linux上设置Ollama服务配置(常用环境变量),Ollama提供了多种环境变量供配置,如调试模式、模型目录等,下面就来介绍一... 目录在 linux 上设置环境变量配置 OllamPOgxSRJfa手动安装安装特定版本查看日志在

Java常用注解扩展对比举例详解

《Java常用注解扩展对比举例详解》:本文主要介绍Java常用注解扩展对比的相关资料,提供了丰富的代码示例,并总结了最佳实践建议,帮助开发者更好地理解和应用这些注解,需要的朋友可以参考下... 目录一、@Controller 与 @RestController 对比二、使用 @Data 与 不使用 @Dat

Mysql中深分页的五种常用方法整理

《Mysql中深分页的五种常用方法整理》在数据量非常大的情况下,深分页查询则变得很常见,这篇文章为大家整理了5个常用的方法,文中的示例代码讲解详细,大家可以根据自己的需求进行选择... 目录方案一:延迟关联 (Deferred Join)方案二:有序唯一键分页 (Cursor-based Paginatio

Python实现常用文本内容提取

《Python实现常用文本内容提取》在日常工作和学习中,我们经常需要从PDF、Word文档中提取文本,本文将介绍如何使用Python编写一个文本内容提取工具,有需要的小伙伴可以参考下... 目录一、引言二、文本内容提取的原理三、文本内容提取的设计四、文本内容提取的实现五、完整代码示例一、引言在日常工作和学

Redis中的常用的五种数据类型详解

《Redis中的常用的五种数据类型详解》:本文主要介绍Redis中的常用的五种数据类型详解,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录Redis常用的五种数据类型一、字符串(String)简介常用命令应用场景二、哈希(Hash)简介常用命令应用场景三、列表(L

python中time模块的常用方法及应用详解

《python中time模块的常用方法及应用详解》在Python开发中,时间处理是绕不开的刚需场景,从性能计时到定时任务,从日志记录到数据同步,时间模块始终是开发者最得力的工具之一,本文将通过真实案例... 目录一、时间基石:time.time()典型场景:程序性能分析进阶技巧:结合上下文管理器实现自动计时

C#中的 Dictionary常用操作

《C#中的Dictionary常用操作》C#中的DictionaryTKey,TValue是用于存储键值对集合的泛型类,允许通过键快速检索值,并且具有唯一键、动态大小和无序集合的特性,常用操作包括添... 目录基本概念Dictionary的基本结构Dictionary的主要特性Dictionary的常用操作

Python中常用的四种取整方式分享

《Python中常用的四种取整方式分享》在数据处理和数值计算中,取整操作是非常常见的需求,Python提供了多种取整方式,本文为大家整理了四种常用的方法,希望对大家有所帮助... 目录引言向零取整(Truncate)向下取整(Floor)向上取整(Ceil)四舍五入(Round)四种取整方式的对比综合示例应

C#中读取XML文件的四种常用方法

《C#中读取XML文件的四种常用方法》Xml是Internet环境中跨平台的,依赖于内容的技术,是当前处理结构化文档信息的有力工具,下面我们就来看看C#中读取XML文件的方法都有哪些吧... 目录XML简介格式C#读取XML文件方法使用XmlDocument使用XmlTextReader/XmlTextWr