Mikroprozessor - 8086-Adressierungsmodi

Die verschiedenen Arten, wie ein Quelloperand in einem Befehl bezeichnet wird, sind bekannt als addressing modes. Es gibt 8 verschiedene Adressierungsmodi in der 8086-Programmierung -

Sofortiger Adressierungsmodus

Der Adressierungsmodus, in dem der Datenoperand Teil des Befehls selbst ist, wird als Sofortadressierungsmodus bezeichnet.

Beispiel

MOV CX, 4929 H, ADD AX, 2387 H,  MOV AL, FFH

Adressierungsmodus registrieren

Dies bedeutet, dass das Register die Quelle eines Operanden für eine Anweisung ist.

Beispiel

MOV CX, AX   ; copies the contents of the 16-bit AX register into  
             ; the 16-bit CX register),  
ADD BX, AX

Direkter Adressierungsmodus

Der Adressierungsmodus, in dem die effektive Adresse des Speicherorts direkt in den Befehl geschrieben wird.

Beispiel

MOV AX, [1592H], MOV AL, [0300H]

Registrieren Sie den indirekten Adressierungsmodus

Dieser Adressierungsmodus ermöglicht die Adressierung von Daten an jedem Speicherort über eine Offset-Adresse, die in einem der folgenden Register gespeichert ist: BP, BX, DI & SI.

Beispiel

MOV AX, [BX]  ; Suppose the register BX contains 4895H, then the contents  
              ; 4895H are moved to AX 
ADD CX, {BX}

Basierter Adressierungsmodus

In diesem Adressierungsmodus wird die Versatzadresse des Operanden durch die Summe der Inhalte der BX / BP-Register und die 8-Bit / 16-Bit-Verschiebung angegeben.

Beispiel

MOV DX, [BX+04], ADD CL, [BX+08]

Indizierter Adressierungsmodus

In diesem Adressierungsmodus wird die Versatzadresse des Operanden durch Hinzufügen des Inhalts des SI- oder DI-Registers und der 8-Bit / 16-Bit-Verschiebungen ermittelt.

Beispiel

MOV BX, [SI+16], ADD AL, [DI+16]

Adressierungsmodus für basierten Index

In diesem Adressierungsmodus wird die Versatzadresse des Operanden berechnet, indem das Basisregister mit dem Inhalt eines Indexregisters summiert wird.

Beispiel

ADD CX, [AX+SI], MOV AX, [AX+DI]

Basierend indiziert mit Verschiebungsmodus

In diesem Adressierungsmodus wird der Operandenversatz durch Hinzufügen des Basisregisterinhalts berechnet. Ein Index registriert Inhalte und 8- oder 16-Bit-Verschiebungen.

Beispiel

MOV AX, [BX+DI+08], ADD CX, [BX+SI+16]