定義

棧是一種具有特殊的訪(fǎng)問(wèn)方式的存儲(chǔ)空間。它的特殊性在于最后進(jìn)入這個(gè)空間的數(shù)據(jù),最先出去,遵循LIFO(后進(jìn)先出)。

CPU提供的棧機(jī)制

CPU[1]提供相關(guān)的指令來(lái)以棧的方式訪(fǎng)問(wèn)內(nèi)存空間,這就意味著在編程的時(shí)候,可以將一段內(nèi)存當(dāng)作棧來(lái)使用。

8086CPU提供入棧[2]和出棧[3]指令,最基本的就是PUSH(入棧)和POP(出棧)。8086CPU的入/出棧都是以字為單位進(jìn)行的。這里舉例說(shuō)明

push ax : 表示將寄存器ax中的數(shù)據(jù)送入棧中
pop  ax : 表示將棧頂?shù)臄?shù)據(jù)送入到寄存器ax中

那么,當(dāng)執(zhí)行push或pop的指令時(shí),CPU是如何確定棧頂單元的呢?
其實(shí)是有相應(yīng)的寄存器來(lái)存放棧頂?shù)牡刂?,?086CPU中,利用段寄存器SS和寄存器SP,棧頂?shù)亩蔚刂反娣旁赟S中,偏移地址存放在SP中。

任意時(shí)刻,SS:SP指向棧頂元素。
push和pop指令執(zhí)行時(shí),CPU從SS和SP中得到棧頂?shù)牡刂贰?

棧頂超界問(wèn)題

棧頂超界的情況:
1.棧滿(mǎn)的時(shí)候,再使用push指令入棧。
2.??盏臅r(shí)候,再使用pop指令出棧。
8086CPU不保證我們對(duì)棧的操作不會(huì)越界,8086CPU只知道棧頂在何處(由SS:SP指示),而不知道我們安排的??臻g有多大。

習(xí)題

1.如果將10000H~1000FH這段空間當(dāng)作棧,初始狀態(tài)棧是空的,此時(shí),SS=1000H,SP=?
2.(1) 將10000H~1000FH這段空間當(dāng)作棧,初始狀態(tài)棧是空的;
(2) 將AX=001AH,BX=001BH;
(3) 將AX、BX中的數(shù)據(jù)入棧;
(4) 將AX、BX消零;
(5) 從棧中恢復(fù)AX、BX原來(lái)的內(nèi)容。


  1. 這里的CPU指的是8086CPU ?

  2. 將一個(gè)新的元素放到棧頂 ?

  3. 從棧頂取出一個(gè)元素 ?

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書(shū)系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容