当英特尔定义最初的8086时,它是一个具有20位地址总线的16位处理器(请参阅下文)。他们定义了8个通用16位寄存器-但为某些指令赋予了它们特定的作用:
AX累加器寄存器。
许多操作码要么假定该寄存器,要么如果指定了该寄存器则更快。
DX数据寄存器。
有时,这会合并为32位值的高16位,AX例如-相乘的结果。
CX计数寄存器。
它在许多面向循环的指令中用作这些循环的隐式计数器-例如LOOPNE(如果不相等,则循环)和REP(重复移动/比较)
BX基址寄存器。
这可以用于索引存储器中结构的基础-以上寄存器均不能用于直接索引到存储器。
SI源索引寄存器。
对于某些移动和比较操作,这是内存中的隐式源索引。
DI目标索引寄存器。
对于某些移动和比较操作,这是内存中的隐式目标索引。
SP堆栈指针寄存器。
这是集合中最少的通用寄存器!它指向堆栈中的当前位置,该位置被显式地用于PUSH和POP操作,隐式地用于子例程CALL和RET与子例程一起使用,在中断期间被隐式地使用。因此,将其用于其他任何事情都对您的程序有害!
BP基本指针寄存器。
当子例程调用其他子例程时,堆栈将保存多个“堆栈帧”。BP可以用来保存当前堆栈帧,然后在调用新的子例程时可以将其保存在堆栈上,创建并使用新的堆栈帧,并在从内部子例程返回时恢复旧的堆栈帧值。
前三个寄存器不能用于索引存储器。
BX,SI并DI通过默认索引到当前数据段(参见下文)。
MOV AX, [BX+5] ; Point into Data Segment
MOV AX, ES:[DI+5] ; Override into Extra Segment
DI在诸如存储器到存储器操作时MOVS和CMPS,单独使用附加段(参见下文)。这不能被覆盖。
SP并BP默认使用堆栈段(请参见下文)。
基本上指令有8->16、8->32、8->64、16->32和16->64。 32->64的转换在哪里?我必须使用签名版本吗? 如果是的话,您如何使用完整的64位来表示无符号整数?
本文向大家介绍verilog 移位寄存器,包括了verilog 移位寄存器的使用技巧和注意事项,需要的朋友参考一下 示例 具有异步复位功能的N位深移位寄存器。
本文向大家介绍Intel x86 Assembly& Microarchitecture 8位寄存器,包括了Intel x86 Assembly& Microarchitecture 8位寄存器的使用技巧和注意事项,需要的朋友参考一下 示例 前四个16位寄存器可以将其高低字节和低半字节直接作为自己的寄存器进行访问: AH和AL是AX寄存器的上半部分和下半部分。 BH和BL是BX寄存器的上半部分和下
本文向大家介绍Intel x86 Assembly& Microarchitecture 32位寄存器,包括了Intel x86 Assembly& Microarchitecture 32位寄存器的使用技巧和注意事项,需要的朋友参考一下 示例 英特尔生产80386时,他们从16位处理器升级到了32位处理器。32位处理意味着两件事:要处理的数据都是32位,而要访问的内存地址是32位。为此,他们仍然
我正在使用x86 Assembly,我遇到了使用指令的需要。 我的代码片段过去是这样的: 其中<代码> 所以我的程序正在命中未定义的行为,在这种情况下是一个无限循环,在检查了很长时间可能出错的地方之后,我认为我必须使用,因为 实际上将结果存储在< code>ax中。因此,我在< code>ax中有一个有符号的结果,而我希望在< code>al中有一个无符号的(有上溢/下溢)结果。 所以我的问题是:
Vim提供了许多寄存器。可以将这些寄存器用作多个剪贴板。使用多个文件时,此功能非常有用。在本章中,将讨论以下主题内容 - 复制寄存器中的文本 粘贴寄存器中的文本 列出可用的寄存器 寄存器类型 1. 复制寄存器中的文本 对于复制,可以使用普通的命令,即并将其存储在寄存器中,可以使用以下语法 - 例如,要复制寄存器中的文本,请使用以下命令 - 2. 粘贴寄存器中的文本 从寄存器粘贴文本 - 例如,下面