0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

單片機(jī)堆棧的小故事讓你更容易理解堆棧的概念

GReq_mcu168 ? 來(lái)源:未知 ? 作者:工程師曾玲 ? 2018-09-23 15:58 ? 次閱讀

因?yàn)?a target="_blank">單片機(jī)CPU、存儲(chǔ)器、IO等等,使他(人性化一點(diǎn)以配合下文)看起來(lái)就像一個(gè)比較小的計(jì)算機(jī),所以在理解單片機(jī)的時(shí)候如果能把你之前有的那些也許僅僅是直覺上的對(duì)計(jì)算機(jī)的理解融入進(jìn)來(lái)的話,可能會(huì)對(duì)你學(xué)習(xí)單片機(jī)的概念有極大的幫助,至少對(duì)于我是這樣的。

我想在關(guān)于單片機(jī)的眾多讓你頭暈?zāi)X脹、摸不著頭腦甚至想撞墻的概念里面,“堆棧”可能是其中最可惡的一個(gè),因?yàn)榧词箚螁问菑臐h語(yǔ)的角度來(lái)理解這個(gè)詞就已經(jīng)讓你很暈了,其實(shí)我最初也想不通這是哪位大俠的創(chuàng)意,不過(guò)不用擔(dān)心,這里我們完全不去討論關(guān)于這個(gè)詞的問(wèn)題(這個(gè)詞用得其實(shí)很好“堆”和“棧”都有他們各自思,準(zhǔn)確的概括了這個(gè)區(qū)域的功能,有興趣可以Baidu一下),這里我會(huì)打一個(gè)比較有趣的比方,以此來(lái)繞過(guò)那些令你想撞墻的概念,并使你在直覺上對(duì)“堆?!边@個(gè)概念有一個(gè)深刻的理解。

你基本上應(yīng)該清楚,單片機(jī)里面是有存儲(chǔ)區(qū)和CPU的,如果你不清楚,那么我剛剛告訴你了,請(qǐng)記住?,F(xiàn)在,請(qǐng)你把單片中的CPU想成一個(gè)人(你完全可以把他想成是你宿舍的那個(gè)天天和你吵嘴的同學(xué),一會(huì)你就會(huì)發(fā)現(xiàn)這會(huì)非常有趣)在這里就叫他C哥吧,不過(guò)這個(gè)人不同于常人,有一些特點(diǎn),一會(huì)我們會(huì)慢慢說(shuō)清楚,現(xiàn)在要告訴你的關(guān)于這個(gè)人的第一個(gè)特點(diǎn)

是:他的記憶能力很差。下面,請(qǐng)你把存儲(chǔ)區(qū)想象成一個(gè)一個(gè)排好的小盒子,這些盒子的作用大致可以分成兩類:1、保存寫有你命令的紙條,比如你在某個(gè)盒子里面的紙條上寫著:去洗我的襪子!;2、保存你的一些東西,比如你那雙正在污染宿舍空氣的臭襪子。因?yàn)镃哥是一個(gè)記憶力不怎么好的人,所以,這些盒子都有自己的編號(hào),以方便他查找。

那么,現(xiàn)在,我們可以來(lái)說(shuō)明一下單片機(jī)是如何工作的了。首先,你要把所有的命令還有需要處理的東西放進(jìn)那些小盒子,比如剛才提到的你那雙待洗的襪子還有那張紙條,這時(shí)你應(yīng)該發(fā)現(xiàn)C哥另一個(gè)特點(diǎn):笨——他只會(huì)做你明確告訴他的事情,也就是說(shuō),如果你沒(méi)有在紙條上寫“去洗我的襪子!”,那么C哥極有可能會(huì)無(wú)動(dòng)于衷地看著你的襪子直到他被熏暈倒,當(dāng)然,更可能的情況是他根本找不到你的襪子…

好了,當(dāng)你把要做的事情和該怎么做寫到盒子里之后,下面的任務(wù)就交給C哥了。C哥做事真的很講原則,他會(huì)按照你給定的順序或者——如果你沒(méi)有給定的話,根據(jù)盒子上面的編號(hào)按照從小到大的順序——一個(gè)一個(gè)地打開盒子,讀取里面的命令、處理相應(yīng)的事件,直到所有的事情都執(zhí)行完畢,他就會(huì)休息。請(qǐng)你牢記這個(gè)簡(jiǎn)單而有趣的過(guò)程,因?yàn)槠鋵?shí)單片機(jī)就是這樣工作的,當(dāng)然,這里忽略了許多細(xì)節(jié),但是這對(duì)你從直覺上理解單片機(jī)的概念以及足夠了。

下面,就要開始說(shuō)明堆棧這個(gè)概念了,思來(lái)想去,還是覺得如果直接把“堆棧”這個(gè)詞用到文中來(lái),實(shí)在不符合本文的風(fēng)格,考慮到其實(shí)“堆?!币彩谴尜A區(qū)(這一點(diǎn)你要記住,堆棧并不是一個(gè)像專用寄存器那樣專門的一個(gè)區(qū)域,它是由你在通用RAM區(qū)指定的。),按照本文的說(shuō)法也就是一些盒子,所以,現(xiàn)在我們把“堆?!备拿坝洃浐凶印?,你可以感覺到,“堆?!钡淖饔煤陀洃浻袠O大的關(guān)系,不過(guò)你也不用在這里糾結(jié)這個(gè)名字的由來(lái),下面我會(huì)說(shuō)的。

現(xiàn)在,請(qǐng)注意,我要開始解釋“記憶盒子”了,也就是“堆?!薄4笾律险f(shuō),“記憶盒子”的作用是當(dāng)C哥執(zhí)行某任務(wù)到一半的時(shí)候突然有了更緊急的是事情要執(zhí)行的時(shí)候用來(lái)保存當(dāng)前任務(wù)的(包括盒子的編號(hào)和盒子里面的東西)。這么說(shuō)你肯定暈了,其實(shí),通俗一點(diǎn),就是當(dāng)C哥洗襪子洗到一半的時(shí)候突然接到你的命令要去打開另一個(gè)盒子(那個(gè)盒子里的紙條上可能寫著“給我換尿布”)并執(zhí)行里面的命令,因?yàn)镃哥記憶力很差,以至于他做完那件緊急的事情后記不起要回到哪個(gè)盒子來(lái)繼續(xù)執(zhí)行“洗襪子”這個(gè)命令,這時(shí)候,他要把現(xiàn)在手頭的東西保存到“記憶盒子”里,要保存的東西有:

1、放著紙條和襪子的盒子的編號(hào)(注意這里其實(shí)是兩項(xiàng)內(nèi)容);

2、那雙襪子。這樣,當(dāng)他執(zhí)行完緊急任務(wù)后會(huì)去記憶盒子里,從里面找到兩張紙條,和一雙襪子(這個(gè)時(shí)候C哥還是沒(méi)有想起來(lái)他要洗襪子,他必須要到那張寫著洗襪子命令的紙條),他按照兩張紙條的信息知道自己要去哪個(gè)盒子去洗襪子,并在那里繼續(xù)完成洗襪子的任務(wù)。你可能會(huì)發(fā)現(xiàn),在這一段的解釋里面有一個(gè)重要的漏洞,那就是在C哥執(zhí)行完緊急任務(wù)后他是如何知道儲(chǔ)存著原來(lái)的任務(wù)信息的盒子的編號(hào)是存儲(chǔ)在哪個(gè)“記憶盒子”里呢?

別著急,下面我會(huì)解釋的。從本質(zhì)來(lái)說(shuō),“記憶盒子”與普通的盒子是沒(méi)有區(qū)別的,他們都是單片機(jī)里面的存儲(chǔ)單元,證明這一點(diǎn)的最好證據(jù)就是堆棧是需要你來(lái)指定的,也就是說(shuō),你要預(yù)先把一些盒子指定為“記憶盒子”。下面,說(shuō)明一下是如何指定“記憶盒子”的。

其實(shí)這個(gè)過(guò)程很簡(jiǎn)單,在單片機(jī)的專用寄存器里面有一個(gè)SP指針(81H),這個(gè)指針里面記錄著堆棧的開始處的地址。用符合本文的話來(lái)解釋就是,C哥的衣服上有一個(gè)口袋(也就是SP指針),這個(gè)口袋里面的“神奇紙條”上記錄著第一個(gè)“記憶盒子”的編號(hào),而指定“記憶盒子”的過(guò)程就是你在這張“神奇紙條”上寫上一個(gè)盒子的編號(hào)(作為第一個(gè)“記憶盒子”的編號(hào)),這個(gè)紙條會(huì)自動(dòng)地將紙條上的編號(hào)加1或者減1,所以,某個(gè)目前并不確定的區(qū)域內(nèi)盒子具備了成為“記憶盒子”的可能,注意,堆棧的大小是不能規(guī)定的,這就是為什么用“生長(zhǎng)”這個(gè)詞來(lái)形容堆棧。

現(xiàn)在,關(guān)于堆棧的概念基本上都介紹完了,但是,我知道,你可能還是很暈,甚至比看之前還暈,那是因?yàn)閯偛艛⑹龅倪@個(gè)過(guò)程是分開的,而且邏輯上并不是順序的,下面,順序的說(shuō)一下,相信你馬上就明白了。主角仍然是傻傻笨笨但任勞任怨的C哥,他一個(gè)一個(gè)的打開盒子按照里面的紙條上的說(shuō)明執(zhí)行你規(guī)定的任務(wù)。而你,為了防止他在執(zhí)行復(fù)雜任務(wù)時(shí)犯傻,把一個(gè)盒子指定為“記憶盒子”,并把這個(gè)“記憶盒子”的位置寫在了一張“神奇紙條”上放在了C哥的口袋里。

現(xiàn)在,C哥正在洗你的襪子,這個(gè)時(shí)候,他突然接到你的命令要去給你換尿布,而C哥知道自己很笨,所以他自動(dòng)地掏出了口袋里的紙條,找到了第一個(gè)“記憶盒子”,然后拿出一張空白紙條,把裝著“給我洗襪子”那張紙條的盒子的編號(hào)寫在了上面并放進(jìn)“記憶子”。然后,他把“神奇紙條”放回了口袋里。當(dāng)這個(gè)任務(wù)完成后“神奇紙條”會(huì)自動(dòng)將寫在它上面的編號(hào)加1也就是將一個(gè)新的、空的“憶盒子”的編號(hào)寫在上面。

之后,他會(huì)按照剛才的過(guò)程把裝著襪子的那個(gè)盒子的以及襪子本身分別放進(jìn)不同的記憶盒子(現(xiàn)在已經(jīng)有三個(gè)盒子成為“記憶盒子”,堆棧已經(jīng)長(zhǎng)大了,紅色下劃線的字體就是這三個(gè)盒子里的內(nèi)容,注意是有先后順序的)。再然后,他就去給你換尿布了… 現(xiàn)在,尿布換完了,不過(guò),果不其然,C哥完全忘記了他要給你洗襪子這件事情了,不過(guò),他記得一件事,那就是看口袋里的紙條。于是,他摸出了口袋里的紙條,上面當(dāng)然是一個(gè)“記憶盒子”的編號(hào),他按照編號(hào)找到了第一個(gè)“記憶盒子”(按照上一段的順序應(yīng)該是第三個(gè)“記憶盒子”),里面應(yīng)該是一雙你的襪子,于是他拿到了你的襪子。但是,他還是不知道。

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問(wèn)題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • 單片機(jī)
    +關(guān)注

    關(guān)注

    6030

    文章

    44489

    瀏覽量

    631973
  • cpu
    cpu
    +關(guān)注

    關(guān)注

    68

    文章

    10804

    瀏覽量

    210829
  • 堆棧
    +關(guān)注

    關(guān)注

    0

    文章

    182

    瀏覽量

    19717

原文標(biāo)題:一個(gè)講透了單片機(jī)堆棧的小故事

文章出處:【微信號(hào):mcu168,微信公眾號(hào):硬件攻城獅】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。

收藏 人收藏

    評(píng)論

    相關(guān)推薦

    詳解STM32單片機(jī)堆棧

    學(xué)習(xí)STM32單片機(jī)的時(shí)候,總是能遇到“堆棧”這個(gè)概念。分享本文,希望對(duì)理解堆棧有幫助。 對(duì)于
    發(fā)表于 01-12 11:30

    對(duì)單片機(jī)堆棧理解

    參考鏈接:對(duì)單片機(jī)堆棧理解STM8數(shù)據(jù)手冊(cè)給出了堆棧的位置及大小。棧是從高到低分配,堆是從低到高分配。堆棧是內(nèi)存中一段連續(xù)的存儲(chǔ)區(qū)域,用來(lái)
    發(fā)表于 02-21 07:29

    合泰單片機(jī)HT48軟件堆棧的應(yīng)用

    對(duì)于 Holtek 八位元單片機(jī)來(lái)說(shuō),堆棧資源往往是有限的。例如,HT48R10A-1 就只有兩級(jí)堆棧。 本文將介紹如何利用軟件堆棧來(lái)解決這一問(wèn)題。軟件
    發(fā)表于 04-20 17:40 ?95次下載

    關(guān)于堆棧的深入理解

    這里提了三個(gè)概念: 堆,棧,以及堆棧。我把棧和堆棧概念等同了。所以,接下來(lái)只要把兩個(gè)概念弄清楚就可以了:堆和棧。先說(shuō)由來(lái)。由于我的工作大部
    的頭像 發(fā)表于 03-04 15:57 ?4177次閱讀
    關(guān)于<b class='flag-5'>堆棧</b>的深入<b class='flag-5'>理解</b>

    51單片機(jī)堆棧的作用和使用資料講解

    堆棧的作用是用在調(diào)用子程序或中斷程序時(shí)保護(hù)現(xiàn)場(chǎng),因?yàn)?1單片機(jī)的寄存器是十分有限的,而相對(duì)來(lái)說(shuō)普通數(shù)據(jù)存儲(chǔ)器充足,通過(guò)入棧將寄存器中的內(nèi)容臨時(shí)保存到堆棧中(普通數(shù)據(jù)存儲(chǔ)器),這是一個(gè)
    發(fā)表于 06-13 17:45 ?2次下載
    51<b class='flag-5'>單片機(jī)</b><b class='flag-5'>堆棧</b>的作用和使用資料講解

    什么是單片機(jī)堆棧?單片機(jī)堆棧有什么作用和原理說(shuō)明

    什么是單片機(jī)堆棧?在片內(nèi)RAM中,常常要指定一個(gè)專門的區(qū)域來(lái)存放某些特別的數(shù)據(jù),它遵循順序存取和后進(jìn)先出(LIFO/FILO)的原則,這個(gè)RAM區(qū)叫堆棧。
    的頭像 發(fā)表于 08-03 09:29 ?2w次閱讀

    51單片機(jī)多任務(wù)定時(shí)器和公共堆棧與私堆棧的源代碼和工程文件

    本文檔的主要內(nèi)容詳細(xì)介紹的是51單片機(jī)多任務(wù)定時(shí)器和公共堆棧與私堆棧的源代碼和工程文件。
    發(fā)表于 12-26 15:37 ?15次下載
    51<b class='flag-5'>單片機(jī)</b>多任務(wù)定時(shí)器和公共<b class='flag-5'>堆棧</b>與私<b class='flag-5'>堆棧</b>的源代碼和工程文件

    STM32單片機(jī)堆棧深入解析

    學(xué)習(xí)STM32單片機(jī)的時(shí)候,總是能遇到堆棧這個(gè)概念。分享本文,希望對(duì)理解堆棧有幫助。 對(duì)于了解
    的頭像 發(fā)表于 10-30 17:31 ?4674次閱讀
    STM32<b class='flag-5'>單片機(jī)</b>的<b class='flag-5'>堆棧</b>深入解析

    一個(gè)簡(jiǎn)短的小故事帶你摸透單片機(jī)堆棧

    對(duì)學(xué)習(xí)單片機(jī)概念有極大的幫助,至少對(duì)于我是這樣的。 我想在關(guān)于單片機(jī)的眾多頭暈?zāi)X脹、摸不
    的頭像 發(fā)表于 10-30 20:55 ?437次閱讀

    單片機(jī)堆棧是什么?它的原理和作用又是什么?

    什么是單片機(jī)堆棧?在片內(nèi)RAM中,常常要指定一個(gè)專門的區(qū)域來(lái)存放某些特別的數(shù)據(jù),它遵循順序存取和后進(jìn)先出(LIFO/FILO)的原則,這個(gè)RAM區(qū)叫堆棧。它的作用子程序調(diào)用和中斷服務(wù)時(shí)CPU自動(dòng)將
    發(fā)表于 11-11 10:51 ?70次下載
    <b class='flag-5'>單片機(jī)</b><b class='flag-5'>堆棧</b>是什么?它的原理和作用又是什么?

    分析單片機(jī)堆棧,分享個(gè)人理解

    看關(guān)于單片機(jī)方面的書籍的時(shí)候,總是能看到別人說(shuō)的一些堆棧啊什么的操作,之前看到這個(gè)術(shù)語(yǔ)就直接跳過(guò),沒(méi)想到去探究單片機(jī)內(nèi)部的原理。但是最近課程學(xué)習(xí)微機(jī)原理這門課,需要我們寫匯編程序,匯編里面經(jīng)常遇到
    發(fā)表于 11-22 09:21 ?6次下載
    分析<b class='flag-5'>單片機(jī)</b><b class='flag-5'>堆棧</b>,分享個(gè)人<b class='flag-5'>理解</b>

    51單片機(jī)堆棧深入剖析

    上的擴(kuò)展,既有C語(yǔ)言的共性,又有它自己的特點(diǎn)。本文介紹的是Cx51程序設(shè)計(jì)時(shí)堆棧的計(jì)算方法。   1.堆棧的溢出問(wèn)題。MCS51系列單片機(jī)堆棧設(shè)置在片內(nèi)RAM中,由于片內(nèi)RAM資源有
    發(fā)表于 11-22 16:36 ?16次下載
    51<b class='flag-5'>單片機(jī)</b><b class='flag-5'>堆棧</b>深入剖析

    詳解STM32單片機(jī)堆棧

    學(xué)習(xí)STM32單片機(jī)的時(shí)候,總是能遇到“堆棧”這個(gè)概念。分享本文,希望對(duì)理解堆棧有幫助。
    發(fā)表于 02-08 15:41 ?5次下載
    詳解STM32<b class='flag-5'>單片機(jī)</b>的<b class='flag-5'>堆棧</b>

    一個(gè)故事看懂單片機(jī)中的堆棧

    理解單片機(jī)的時(shí)候如果能把之前有的那些也許僅僅是直覺上的對(duì)計(jì)算機(jī)的理解融入進(jìn)來(lái)的話,可能會(huì)對(duì)學(xué)習(xí)單片
    發(fā)表于 02-08 17:00 ?0次下載
    一個(gè)<b class='flag-5'>故事</b>看懂<b class='flag-5'>單片機(jī)</b>中的<b class='flag-5'>堆棧</b>

    普通單片機(jī)與STM32單片機(jī)堆棧的區(qū)別

    學(xué)習(xí)STM32單片機(jī)的時(shí)候,總是能遇到“堆棧”這個(gè)概念。分享本文,希望對(duì)理解堆棧有幫助。
    的頭像 發(fā)表于 04-13 11:15 ?3125次閱讀