Tříadresní kód

Technology
12 hours ago
8
4
2
Avatar
Author
Albert Flores

Tříadresní kód (často označovaný jako tříadresný kód nebo tříadresový kód) označuje v informatice formu mezijazyka, používanou překladačem jako pomůcku pro optimalizaci kódu. Každý příkaz v tříadresním kódu je zapsán pomocí uspořádané čtveřice: operátor, operand1, operand2 a výsledek.

Zápis

Každý výrok pak má obecný zápis:

\text{vysledek} := \text{operand}_1 \, \operatorname{operator} \, \text{operand}_2\,

jako například:

x := y \, \operatorname{op} \, z\,

kde x, y a z jsou proměnné, konstanty nebo dočasné proměnné generované překladačem. Symbol op představuje libovolný operátor, například aritmetický součet.

Výrazy, které obsahují více než jednu klíčovou operaci, například:

p := x + y \times z\,

nejsou reprezentované v tříadresním kódu jako jeden příkaz. Místo toho se rozloží na ekvivalentní řadu příkazů jako například:

t_1 := y \times z\,

p := x + t_1\,

Pojem tříadresní kód se používá i tehdy, kdy některé příkazy obsahují více (nebo naopak méně) než dva operandy. Klíčová vlastnost tříadresního kódu je, že každý příkaz obsahuje právě jednu operaci, a že zdroj i cíl se vztahují k jakémukoliv dostupnému registru.

Zdokonalením tříadresního kódu je tzv. SSA forma.

Příklad

int main(void) { int i; int b[10]; for (i = 0; i Výše uvedený program jazyka C, přeložený do tříadresního kódu, by mohl vypadat následovně:

i := 0 ; přiřazení L1: if i >= 10 goto L2 ; podmíněný skok t0 := i*i t1 := &b ; adresa operace t2 := t1 + i ; přiřazení hodnoty t2 k adrese b[i] *t2 := t0 ; uložení operace prostřednictvím ukazatele i := i + 1 goto L1 L2:

Související články

Mezijazyk * RISC

Reference

Externí odkazy

[url=http://www.cs.arizona.edu/classes/cs453/fall07/DOCS/intcode.html]CSc 453: A Three-Address Intermediate Code Instruction Set for C--[/url]

Kategorie:Překladače

5 min read
Share this post:
Like it 8

Leave a Comment

Please, enter your name.
Please, provide a valid email address.
Please, enter your comment.
Enjoy this post? Join Cesko.wiki
Don’t forget to share it
Top