資料介紹
今天放松一下,我們來看看數(shù)據(jù)結(jié)構(gòu)中的棧,這節(jié)的知識點(diǎn)可以說是數(shù)據(jù)結(jié)構(gòu)中最容易上手的知識點(diǎn)了,其實(shí)比起鏈表,其實(shí)鏈表也有棧和隊(duì)列的模型,鏈表的頭插其實(shí)就是后進(jìn)先出,鏈表的尾插其實(shí)就是先進(jìn)先出,這不就是棧和隊(duì)列嗎,哈哈,不知道學(xué)習(xí)數(shù)據(jù)結(jié)構(gòu)的時(shí)候有沒有意識到這一點(diǎn),但是棧和隊(duì)列和鏈表還是有所區(qū)別的,我們來看看。
首先了解一下,什么是棧? 棧(stack)又名堆棧,它是一種運(yùn)算受限的線性表。其限制是僅允許在表的一端進(jìn)行插入和刪除運(yùn)算。這一端被稱為棧頂,相對地,把另一端稱為棧底。向一個(gè)棧插入新元素又稱作進(jìn)棧、入棧或壓棧,它是把新元素放到棧頂元素的上面,使之成為新的棧頂元素;從一個(gè)棧刪除元素又稱作出?;蛲藯#前褩m斣貏h除掉,使其相鄰的元素成為新的棧頂元素。??梢杂脕碓诤瘮?shù)調(diào)用的時(shí)候存儲斷點(diǎn),做遞歸時(shí)要用到棧!最著名的實(shí)例便是漢諾塔,漢諾塔可以用遞歸來實(shí)現(xiàn)。棧的生長方向是從高地址到低地址。每個(gè)函數(shù)的每次調(diào)用,都有它自己獨(dú)立的一個(gè)棧幀,這個(gè)棧幀中維持著所需要的各種信息。寄存器ebp指向當(dāng)前的棧幀的底部(高地址),寄存器esp指向當(dāng)前的棧幀的頂部(低地址)。注意:EBP指向當(dāng)前位于系統(tǒng)棧最上邊一個(gè)棧幀的底部,而不是系統(tǒng)棧的底部。嚴(yán)格說來,“棧幀底部”和“棧底”是不同的概念;ESP所指的棧幀頂部和系統(tǒng)棧的頂部是同一個(gè)位置。在操作系統(tǒng)中,每一個(gè)線程都有一個(gè)棧,但是每個(gè)應(yīng)用程序通常都只有一個(gè)堆,當(dāng)然在為不同類型分配內(nèi)存的時(shí)候使用多個(gè)堆并不是不可能。
那棧有什么特點(diǎn)?
1. 和堆一樣存儲在計(jì)算機(jī) RAM 中。
2. 在棧上創(chuàng)建變量的時(shí)候會擴(kuò)展,并且會自動回收。
3. 相比堆而言在棧上分配要快的多。
4. 用數(shù)據(jù)結(jié)構(gòu)中的棧實(shí)現(xiàn)。
5. 存儲局部數(shù)據(jù),返回地址,用做參數(shù)傳遞。
6. 當(dāng)用棧過多時(shí)可導(dǎo)致棧溢出(無窮次(大量的)的遞歸調(diào)用,或者大量的內(nèi)存分配)。
7. 在棧上的數(shù)據(jù)可以直接訪問(不是非要使用指針訪問)。
8. 如果你在編譯之前精確的知道你需要分配數(shù)據(jù)的大小并且不是太大的時(shí)候,可以使用棧。
9. 當(dāng)你程序啟動時(shí)決定棧的容量上限。
- PLC實(shí)現(xiàn)入棧出棧功能(SCL)
- PLC實(shí)現(xiàn)入棧出棧功能
- pycharm 遞歸 棧溢出_STM32編程:是時(shí)候深入理解棧了<一>
- STM32編程:動畫深度演示棧機(jī)制、棧溢出
- 單片機(jī)中堆和棧的區(qū)別
- ZStack協(xié)議棧資源下載 19次下載
- ZigBee2007協(xié)議棧的API函數(shù)使用說明資料免費(fèi)下載 29次下載
- JAVA的堆和棧介紹和內(nèi)存機(jī)制中堆和棧的區(qū)別及變量在內(nèi)存中的分配
- 在程序的內(nèi)存分配中堆和棧什么樣的區(qū)別
- 什么是數(shù)據(jù)結(jié)構(gòu)?為什么要學(xué)習(xí)數(shù)據(jù)結(jié)構(gòu)?數(shù)據(jù)結(jié)構(gòu)的應(yīng)用實(shí)例分析 14次下載
- 為什么要學(xué)習(xí)數(shù)據(jù)結(jié)構(gòu)?數(shù)據(jù)結(jié)構(gòu)的應(yīng)用詳細(xì)資料概述免費(fèi)下載 13次下載
- TCP/IP協(xié)議棧之路由器簡要分析 1次下載
- ZigBee2007協(xié)議棧API函數(shù)使用說明
- oSIP協(xié)議棧的研究及應(yīng)用 15次下載
- 數(shù)據(jù)結(jié)構(gòu)課件 0次下載
- 堆和棧的區(qū)別和使用注意事項(xiàng) 2280次閱讀
- Linux中的進(jìn)程棧、線程棧、內(nèi)核棧以及中斷棧 735次閱讀
- 堆和棧的增長方向?yàn)槭裁赐ǔJ窍喾吹模?/a> 9103次閱讀
- 使用協(xié)議棧實(shí)現(xiàn)Modbus ASCII從站應(yīng)用 1314次閱讀
- 使用協(xié)議棧實(shí)現(xiàn)Modbus ASCII主站應(yīng)用 999次閱讀
- 使用協(xié)議棧實(shí)現(xiàn)Modbus RTU從站應(yīng)用 2097次閱讀
- 使用協(xié)議棧實(shí)現(xiàn)Modbus RTU主站應(yīng)用 1690次閱讀
- SystemVerilog中可以嵌套的數(shù)據(jù)結(jié)構(gòu) 1639次閱讀
- 內(nèi)存池在棧結(jié)構(gòu)中的性能設(shè)計(jì)實(shí)現(xiàn) 846次閱讀
- 關(guān)于堆和棧的理論知識 1379次閱讀
- 數(shù)據(jù)結(jié)構(gòu)中堆棧出棧序列問題解析 3394次閱讀
- MSP430數(shù)組填充越界引起的棧溢出導(dǎo)致程序跑飛如何解決 4791次閱讀
- 你還會手寫棧和隊(duì)列嗎棧和隊(duì)列的基本實(shí)現(xiàn)程序說明 2821次閱讀
- C++中的棧和堆區(qū)別 4826次閱讀
- java數(shù)據(jù)結(jié)構(gòu)學(xué)習(xí) 794次閱讀
下載排行
本周
- 1常用電子元器件集錦
- 1.72 MB | 24485次下載 | 免費(fèi)
- 2ssd1306單片 CMOS OLED/PLED 驅(qū)動芯片中文手冊
- 1.66 MB | 4次下載 | 1 積分
- 3低壓降肖特基整流管SR340L數(shù)據(jù)手冊
- 0.78 MB | 2次下載 | 免費(fèi)
- 4高壓MOS管MDD12N65F/MDD12N65P數(shù)據(jù)手冊
- 2.36 MB | 2次下載 | 免費(fèi)
- 5FP6195 60V、800mA、480KHz異步降壓轉(zhuǎn)換器規(guī)格書
- 0.88 MB | 2次下載 | 免費(fèi)
- 6CPCI6310型復(fù)合視頻采集板資料
- 0.04 MB | 1次下載 | 免費(fèi)
- 7STM32F10xxx參考手冊
- 13.64 MB | 1次下載 | 1 積分
- 8PC2456高壓浪涌抑制器控制器數(shù)據(jù)手冊
- 3.03 MB | 1次下載 | 免費(fèi)
本月
- 1常用電子元器件集錦
- 1.72 MB | 24485次下載 | 免費(fèi)
- 2三相逆變主電路的原理圖和PCB資料合集免費(fèi)下載
- 27.35 MB | 111次下載 | 1 積分
- 3運(yùn)算放大器基本電路中文資料
- 1.30 MB | 16次下載 | 免費(fèi)
- 4蘋果iphone 11電路原理圖
- 4.98 MB | 12次下載 | 5 積分
- 5常用電子元器件介紹
- 3.21 MB | 10次下載 | 免費(fèi)
- 6EMC電路設(shè)計(jì)工程師必備的EMC基礎(chǔ)
- 0.42 MB | 6次下載 | 2 積分
- 7相關(guān)協(xié)議信號總結(jié)
- 0.94 MB | 4次下載 | 免費(fèi)
- 8ssd1306單片 CMOS OLED/PLED 驅(qū)動芯片中文手冊
- 1.66 MB | 4次下載 | 1 積分
總榜
- 1matlab軟件下載入口
- 未知 | 935130次下載 | 10 積分
- 2開源硬件-PMP21529.1-4 開關(guān)降壓/升壓雙向直流/直流轉(zhuǎn)換器 PCB layout 設(shè)計(jì)
- 1.48MB | 420064次下載 | 10 積分
- 3Altium DXP2002下載入口
- 未知 | 233089次下載 | 10 積分
- 4電路仿真軟件multisim 10.0免費(fèi)下載
- 340992 | 191390次下載 | 10 積分
- 5十天學(xué)會AVR單片機(jī)與C語言視頻教程 下載
- 158M | 183345次下載 | 10 積分
- 6labview8.5下載
- 未知 | 81591次下載 | 10 積分
- 7Keil工具M(jìn)DK-Arm免費(fèi)下載
- 0.02 MB | 73816次下載 | 10 積分
- 8LabVIEW 8.6下載
- 未知 | 65989次下載 | 10 積分
評論