8086CPU汇编寻址方式解析

需积分: 10 0 下载量 109 浏览量 更新于2024-08-30 收藏 516KB DOCX 举报
"8086CPU汇编寻址原理" 在8086 CPU的汇编语言编程中,寻址方式是理解程序执行的关键部分。本文档主要探讨了不涉及段寄存器DS与SS的寻址以及涉及到段寄存器的寻址原理。 首先,我们来看不涉及段寄存器的寻址方式: 1. **直接寻址**:通过直接给出数值来指定操作数。例如,`mov ax, 1234h`将16位数值1234h加载到AX寄存器中。对于8位寄存器,如`mov al, 34h`,34h会被直接放入AL寄存器,因为AL是8位的,所以34h即为完整的值。 2. **寄存器间转移**:数据可以从一个寄存器转移到另一个寄存器。例如,`mov ax, bx`将BX寄存器的内容移到AX寄存器。在寄存器间转移时,位数需保持一致,不能将16位寄存器的内容直接放入8位寄存器,反之亦然,否则会导致数据丢失或错误。 然后,我们讨论涉及段寄存器DS与SS的寻址: 1. **内存寻址**:当使用方括号`[]`时,通常涉及内存访问。例如,`mov ax, [0]`会从数据段DS的偏移地址0处取出两个字节的数据放入AX寄存器。数据的大小取决于目的寄存器,如AX接收16位数据,AL接收8位数据。在内存访问中,数据的高低位存储顺序遵循“下高上低,前高后低”的原则。 - **默认段寄存器**:在没有指定段寄存器的情况下,[]中的地址默认关联于数据段DS。如`mov ax, [4]`意味着从DS:4的位置取数据。 - **指定段寄存器**:若需使用其他段寄存器,可以明确指定,如`mov ax, es:[100h]`。 内存寻址还涉及到**基址和变址寄存器**: - **基址寄存器**:BX、BP,它们可以作为偏移地址的基础。 - **变址寄存器**:SI、DI,它们可以用来增加或减少基址以形成不同的内存地址。 例如,`mov ax, [BX]`会从DS段中,由BX寄存器值指定的地址读取数据到AX。如果加上偏移量,如`mov ax, [BX+5]`,则会从DS:BX+5的地址读取数据。 总结来说,8086汇编语言的寻址原理涉及到直接寻址、寄存器间转移以及内存寻址,包括默认段寻址和指定段寻址。理解这些基本概念对于编写有效的8086汇编程序至关重要。在处理内存访问时,注意段寄存器的选择,以及如何结合基址和变址寄存器构建不同的内存地址,是确保程序正确执行的关键。