汇编语言中常用的寄存器

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

相关文章

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

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

CSS弹性布局常用设置方式

《CSS弹性布局常用设置方式》文章总结了CSS布局与样式的常用属性和技巧,包括视口单位、弹性盒子布局、浮动元素、背景和边框样式、文本和阴影效果、溢出隐藏、定位以及背景渐变等,通过这些技巧,可以实现复杂... 一、单位元素vm 1vm 为视口的1%vh 视口高的1%vmin 参照长边vmax 参照长边re

Python中操作Redis的常用方法小结

《Python中操作Redis的常用方法小结》这篇文章主要为大家详细介绍了Python中操作Redis的常用方法,文中的示例代码简洁易懂,具有一定的借鉴价值,有需要的小伙伴可以了解一下... 目录安装Redis开启、关闭Redisredis数据结构redis-cli操作安装redis-py数据库连接和释放增

一文详解Python中数据清洗与处理的常用方法

《一文详解Python中数据清洗与处理的常用方法》在数据处理与分析过程中,缺失值、重复值、异常值等问题是常见的挑战,本文总结了多种数据清洗与处理方法,文中的示例代码简洁易懂,有需要的小伙伴可以参考下... 目录缺失值处理重复值处理异常值处理数据类型转换文本清洗数据分组统计数据分箱数据标准化在数据处理与分析过

Java中Object类的常用方法小结

《Java中Object类的常用方法小结》JavaObject类是所有类的父类,位于java.lang包中,本文为大家整理了一些Object类的常用方法,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1. public boolean equals(Object obj)2. public int ha

Java 字符数组转字符串的常用方法

《Java字符数组转字符串的常用方法》文章总结了在Java中将字符数组转换为字符串的几种常用方法,包括使用String构造函数、String.valueOf()方法、StringBuilder以及A... 目录1. 使用String构造函数1.1 基本转换方法1.2 注意事项2. 使用String.valu

VUE动态绑定class类的三种常用方式及适用场景详解

《VUE动态绑定class类的三种常用方式及适用场景详解》文章介绍了在实际开发中动态绑定class的三种常见情况及其解决方案,包括根据不同的返回值渲染不同的class样式、给模块添加基础样式以及根据设... 目录前言1.动态选择class样式(对象添加:情景一)2.动态添加一个class样式(字符串添加:情

Java 枚举的常用技巧汇总

《Java枚举的常用技巧汇总》在Java中,枚举类型是一种特殊的数据类型,允许定义一组固定的常量,默认情况下,toString方法返回枚举常量的名称,本文提供了一个完整的代码示例,展示了如何在Jav... 目录一、枚举的基本概念1. 什么是枚举?2. 基本枚举示例3. 枚举的优势二、枚举的高级用法1. 枚举

IDEA常用插件之代码扫描SonarLint详解

《IDEA常用插件之代码扫描SonarLint详解》SonarLint是一款用于代码扫描的插件,可以帮助查找隐藏的bug,下载并安装插件后,右键点击项目并选择“Analyze”、“Analyzewit... 目录SonajavascriptrLint 查找隐藏的bug下载安装插件扫描代码查看结果总结Sona

HarmonyOS学习(七)——UI(五)常用布局总结

自适应布局 1.1、线性布局(LinearLayout) 通过线性容器Row和Column实现线性布局。Column容器内的子组件按照垂直方向排列,Row组件中的子组件按照水平方向排列。 属性说明space通过space参数设置主轴上子组件的间距,达到各子组件在排列上的等间距效果alignItems设置子组件在交叉轴上的对齐方式,且在各类尺寸屏幕上表现一致,其中交叉轴为垂直时,取值为Vert