資料介紹
今天放松一下,我們來看看數據結構中的棧,這節的知識點可以說是數據結構中最容易上手的知識點了,其實比起鏈表,其實鏈表也有棧和隊列的模型,鏈表的頭插其實就是后進先出,鏈表的尾插其實就是先進先出,這不就是棧和隊列嗎,哈哈,不知道學習數據結構的時候有沒有意識到這一點,但是棧和隊列和鏈表還是有所區別的,我們來看看。
首先了解一下,什么是棧? 棧(stack)又名堆棧,它是一種運算受限的線性表。其限制是僅允許在表的一端進行插入和刪除運算。這一端被稱為棧頂,相對地,把另一端稱為棧底。向一個棧插入新元素又稱作進棧、入棧或壓棧,它是把新元素放到棧頂元素的上面,使之成為新的棧頂元素;從一個棧刪除元素又稱作出棧或退棧,它是把棧頂元素刪除掉,使其相鄰的元素成為新的棧頂元素。棧可以用來在函數調用的時候存儲斷點,做遞歸時要用到棧!最著名的實例便是漢諾塔,漢諾塔可以用遞歸來實現。棧的生長方向是從高地址到低地址。每個函數的每次調用,都有它自己獨立的一個棧幀,這個棧幀中維持著所需要的各種信息。寄存器ebp指向當前的棧幀的底部(高地址),寄存器esp指向當前的棧幀的頂部(低地址)。注意:EBP指向當前位于系統棧最上邊一個棧幀的底部,而不是系統棧的底部。嚴格說來,“棧幀底部”和“棧底”是不同的概念;ESP所指的棧幀頂部和系統棧的頂部是同一個位置。在操作系統中,每一個線程都有一個棧,但是每個應用程序通常都只有一個堆,當然在為不同類型分配內存的時候使用多個堆并不是不可能。
那棧有什么特點?
1. 和堆一樣存儲在計算機 RAM 中。
2. 在棧上創建變量的時候會擴展,并且會自動回收。
3. 相比堆而言在棧上分配要快的多。
4. 用數據結構中的棧實現。
5. 存儲局部數據,返回地址,用做參數傳遞。
6. 當用棧過多時可導致棧溢出(無窮次(大量的)的遞歸調用,或者大量的內存分配)。
7. 在棧上的數據可以直接訪問(不是非要使用指針訪問)。
8. 如果你在編譯之前精確的知道你需要分配數據的大小并且不是太大的時候,可以使用棧。
9. 當你程序啟動時決定棧的容量上限。
- PLC實現入棧出棧功能(SCL)
- PLC實現入棧出棧功能
- pycharm 遞歸 棧溢出_STM32編程:是時候深入理解棧了<一>
- STM32編程:動畫深度演示棧機制、棧溢出
- 單片機中堆和棧的區別
- ZStack協議棧資源下載 19次下載
- ZigBee2007協議棧的API函數使用說明資料免費下載 28次下載
- JAVA的堆和棧介紹和內存機制中堆和棧的區別及變量在內存中的分配
- 在程序的內存分配中堆和棧什么樣的區別
- 什么是數據結構?為什么要學習數據結構?數據結構的應用實例分析 14次下載
- 為什么要學習數據結構?數據結構的應用詳細資料概述免費下載 13次下載
- TCP/IP協議棧之路由器簡要分析 1次下載
- ZigBee2007協議棧API函數使用說明
- oSIP協議棧的研究及應用 15次下載
- 數據結構課件 0次下載
- 堆和棧的區別和使用注意事項 1472次閱讀
- Linux中的進程棧、線程棧、內核棧以及中斷棧 611次閱讀
- 堆和棧的增長方向為什么通常是相反的? 7665次閱讀
- 使用協議棧實現Modbus ASCII從站應用 1132次閱讀
- 使用協議棧實現Modbus ASCII主站應用 830次閱讀
- 使用協議棧實現Modbus RTU從站應用 1789次閱讀
- 使用協議棧實現Modbus RTU主站應用 1479次閱讀
- SystemVerilog中可以嵌套的數據結構 1448次閱讀
- 內存池在棧結構中的性能設計實現 735次閱讀
- 關于堆和棧的理論知識 1286次閱讀
- 數據結構中堆棧出棧序列問題解析 3175次閱讀
- MSP430數組填充越界引起的棧溢出導致程序跑飛如何解決 4610次閱讀
- 你還會手寫棧和隊列嗎棧和隊列的基本實現程序說明 2728次閱讀
- C++中的棧和堆區別 4712次閱讀
- java數據結構學習 728次閱讀
下載排行
本周
- 1電子電路原理第七版PDF電子教材免費下載
- 0.00 MB | 1490次下載 | 免費
- 2單片機典型實例介紹
- 18.19 MB | 92次下載 | 1 積分
- 3S7-200PLC編程實例詳細資料
- 1.17 MB | 27次下載 | 1 積分
- 4筆記本電腦主板的元件識別和講解說明
- 4.28 MB | 18次下載 | 4 積分
- 5開關電源原理及各功能電路詳解
- 0.38 MB | 10次下載 | 免費
- 6基于AT89C2051/4051單片機編程器的實驗
- 0.11 MB | 4次下載 | 免費
- 7藍牙設備在嵌入式領域的廣泛應用
- 0.63 MB | 3次下載 | 免費
- 89天練會電子電路識圖
- 5.91 MB | 3次下載 | 免費
本月
- 1OrCAD10.5下載OrCAD10.5中文版軟件
- 0.00 MB | 234313次下載 | 免費
- 2PADS 9.0 2009最新版 -下載
- 0.00 MB | 66304次下載 | 免費
- 3protel99下載protel99軟件下載(中文版)
- 0.00 MB | 51209次下載 | 免費
- 4LabView 8.0 專業版下載 (3CD完整版)
- 0.00 MB | 51043次下載 | 免費
- 5555集成電路應用800例(新編版)
- 0.00 MB | 33562次下載 | 免費
- 6接口電路圖大全
- 未知 | 30320次下載 | 免費
- 7Multisim 10下載Multisim 10 中文版
- 0.00 MB | 28588次下載 | 免費
- 8開關電源設計實例指南
- 未知 | 21539次下載 | 免費
總榜
- 1matlab軟件下載入口
- 未知 | 935053次下載 | 免費
- 2protel99se軟件下載(可英文版轉中文版)
- 78.1 MB | 537791次下載 | 免費
- 3MATLAB 7.1 下載 (含軟件介紹)
- 未知 | 420026次下載 | 免費
- 4OrCAD10.5下載OrCAD10.5中文版軟件
- 0.00 MB | 234313次下載 | 免費
- 5Altium DXP2002下載入口
- 未知 | 233045次下載 | 免費
- 6電路仿真軟件multisim 10.0免費下載
- 340992 | 191183次下載 | 免費
- 7十天學會AVR單片機與C語言視頻教程 下載
- 158M | 183277次下載 | 免費
- 8proe5.0野火版下載(中文版免費下載)
- 未知 | 138039次下載 | 免費
評論
查看更多