Naar inhoud springen

Programmeren in TI-83+ Assembly/Assembly-basis/De stack

Uit Wikibooks

Programmeren in TI-83+ Assembly

Voorblad / Inhoudsopgave

Assembly-basis

1 · 2 · 3 · 4 · 5 · T

Controle

1 · 2 · 3 · 4 · 5 · T

Geheugenbeheer

1 · 2 · 3 · 4 · 5 · T

Input en output

1 · 2 · 3 · 4 · 5 · T

Tekenen

1 · 2 · 3 · 4 · 5 · T

Registers en procedures

1 · 2 · 3 · 4 · 5 · T

Applications

1 · 2 · 3 · 4 · T

Gebruikersvariabelen

1 · T

Extra

1 · T

Speciaal

In plaats van variabelen, kun je om registers op te slaan en weer in te lezen ook de stack gebruiken. De stack is een soort rij met getallen. Stel het je voor als een toren met blokken. Je kunt alleen blokken erbij of eraf halen aan de bovenkant. Wat je dus het eerste erin legt komt er het laatste weer uit. Met de stack kun je ook maar twee dingen doen: een registerpaar er 'aan de bovenkant opleggen' en een registerpaar er 'aan de bovenkant afhalen'.

De stack gebruiken

[bewerken]

Een registerpaar op de stack leggen

[bewerken]

Je kunt alleen registerparen toevoegen aan de stack (dus af, bc, de, hl). Als je bijvoorbeeld af op de stack wilt leggen, gaat dit als volgt.

    push af

Wil je bijvoorbeeld a opslaan op de stack, dan moet je f erbij nemen, omdat je alleen maar registerparen kunt opslaan in de stack.

Een registerpaar van de stack afhalen

[bewerken]

Je kunt aan de 'bovenkant' van de stack een getal afhalen en deze weer opslaan in een registerpaar. Als je bijvoorbeeld het bovenste getal van de stack wilt halen en dit opslaan in af, gaat dat als volgt:

    pop af

Een praktische toepassing

[bewerken]

Je weet al dat je er bij bcalls vanuit moet gaan dat alle registers veranderd worden. Wil je a bijvoorbeeld bewaren, maar moet er een instructie uitgevoerd worden, kan dat eenvoudig met de stack:

    push af
    ; bcall
    pop af

a is nu weer teruggebracht in zijn oude staat, dus hoe hij was voordat de instructie werd uitgevoerd.

Een weergave van het gebruik van de stack zie je hieronder.

Iedere keer als iets op de stack gelegd wordt, dan komt dit "bovenop de toren" te liggen. Je kunt dan niet meer direct bij onderliggende getallen.
Merk op dat je een getal dat op de stack ligt, er weer met een ander registerpaar vanaf kunt halen. Dat gebeurt hier bijvoorbeeld met af/de.

Problemen bij het gebruik van de stack

[bewerken]

Er is iets waar je bij het gebruik van de stack heel goed op moet letten. Het besturingssysteem van de TI gebruikt de stack zelf namelijk ook, namelijk om op te slaan waar hij terug moet keren na afloop van het programma. Je moet de stack dus precies hetzelfde achterlaten als hij was toen het programma startte, want anders springt TI-OS ergens anders heen terug en dat is hoogstwaarschijnlijk geen nuttige programmacode. Zie het volgende voorbeeld.

    ; start van het programma
    push af
    push hl
    pop af
    ret     ; terug naar de TI-OS

Als het programma wordt beëindigd, veroorzaak je direct een crash (dus het RAM wordt gewist), omdat de stack, en dus het 'bovenste' getal, niet meer hetzelfde is als vóór het programma.

Zorg er dus voor dat de stack altijd gelijk is vóór en na je programma!

Verder kan het programma crashen als je heel veel registerparen op de stack legt (bij ongeveer 100).

Opdracht

[bewerken]

De bcall _PutS vernielt het registerpaar hl. Schrijf een programma dat iets naar het scherm schrijft met _PutS en hl van het begin van het programma bewaart. Tip: met bcall(_DispHL) kun je hl wegschrijven naar het scherm om te kijken of je het goed gedaan hebt.

Als het niet lukt, kijk dan hieronder voor het antwoord.
Klap uit voor het antwoord
    bcall(_ClrLCDFull)

    ; hl gaat dadelijk vernield worden, dus we zetten hem op de stack:
    push hl

    ; Als eerste laten we hl even zien op het scherm:
    bcall(_DispHL)
    bcall(_NewLine)

    ; Nu de tekst weergeven:
    ld hl, 0
    ld (CurCol), hl
    ld hl, Tekst
    bcall(_PutS)
    bcall(_NewLine)

    ; We outputten hl om te laten zien dat hij inderdaad vernield is:
    bcall(_DispHL)
    bcall(_NewLine)

    ; hl wordt weer van de stack gelezen:
    pop hl

    ; We kunnen zien dat hl weer hersteld is:
    bcall(_DispHL)
    bcall(_NewLine)

    ; Terug naar het TI-OS:
    ret

Tekst:
    .db "Dit is een tekst", 0
Bij het draaien zie je drie cijfers. Het eerste en het derde zouden gelijk moeten zijn, dan is hl behouden.

Het antwoord staat achterin het boek.


← Variabelen De stack Toets hoofdstuk 1 →
Informatie afkomstig van https://nl.wikibooks.org Wikibooks NL.
Wikibooks NL is onderdeel van de wikimediafoundation.