資料介紹
在計機(jī)領(lǐng)域,堆棧是一個不容忽視的概念,我們編寫的C語言程序基本上都要用到。但對于很多的初學(xué)著來說,堆棧是一個很模糊的概念。堆棧:一種數(shù)據(jù)結(jié)構(gòu)、一個在程序運行時用于存放的地方,這可能是很多初學(xué)者的認(rèn)識,因為我曾經(jīng)就是這么想的和匯編語言中的堆棧一詞混為一談。我身邊的一些編程的朋友以及在網(wǎng)上看帖遇到的朋友中有好多也說不清堆棧,所以我想有必要給大家分享一下我對堆棧的看法,有說的不對的地方請朋友們不吝賜教,這對于大家學(xué)習(xí)會有很大幫助。
首先了解下計算機(jī)C語言中各個變量的存放區(qū)域:
代碼區(qū)(CODE): 存放函數(shù)代碼;
靜態(tài)數(shù)據(jù)區(qū)(DATA): 存放全局變理/靜態(tài)變量;
堆區(qū)(HEAP): 是自由存儲區(qū),存放動態(tài)數(shù)據(jù),像new,malloc()申請的空間就是堆區(qū)的;
棧區(qū)(STACK): 存放臨時/局部變量。
數(shù)據(jù)結(jié)構(gòu)的棧和堆
首先在數(shù)據(jù)結(jié)構(gòu)上要知道堆棧,盡管我們這么稱呼它,但實際上堆棧是兩種數(shù)據(jù)結(jié)構(gòu):堆和棧。堆和棧都是一種數(shù)據(jù)項按序排列的數(shù)據(jù)結(jié)構(gòu)。
棧就像裝數(shù)據(jù)的桶或箱子
我們先從大家比較熟悉的棧說起吧,它是一種具有 后進(jìn)先出 性質(zhì)的數(shù)據(jù)結(jié)構(gòu),也就是說后存放的先取,先存放的后取。這就如同我們要取出放在箱子里面底下的東西(放入的比較早的物體),我們首先要移開壓在它上面的物體(放入的比較晚的物體)。
堆像一棵倒過來的樹
而堆就不同了,堆是一種 經(jīng)過排序的樹形數(shù)據(jù)結(jié)構(gòu) ,每個結(jié)點都有一個值。通常我們所說的堆的數(shù)據(jù)結(jié)構(gòu),是指二叉堆。堆的特點是根結(jié)點的值最小(或最大),且根結(jié)點的兩個子樹也是一個堆。由于堆的這個特性,常用來實現(xiàn)優(yōu)先隊列, 堆的存取是隨意 ,這就如同我們在圖書館的書架上取書,雖然書的擺放是有順序的,但是我們想取任意一本時不必像棧一樣,先取出前面所有的書,書架這種機(jī)制不同于箱子,我們可以直接取出我們想要的書。
- 基于VHDL語言中數(shù)字鐘的整點報時源代碼下載 2次下載
- 51單片機(jī)實戰(zhàn)教程之C語言基礎(chǔ)(四 C語言變量定義)
- C語言中的__attribute__宏定義之section屬性
- 【串口屏LUA教程】Lua腳本語言中文教程
- 堆棧在C語言中的定義(單片機(jī)的中堆棧相當(dāng)于棧)資料下載
- C語言中的文件包含詳細(xì)資料總結(jié)
- 單片機(jī)C語言中如何使用nop函數(shù)進(jìn)行短延時的效果資料和程序說明 10次下載
- C語言入門教程之堆棧的詳細(xì)資料概述 12次下載
- C51單片機(jī)C語言與標(biāo)準(zhǔn)C語言有什么區(qū)別? 134次下載
- C語言教程之C語言中級培訓(xùn)教程—預(yù)處理電子課件免費下載 0次下載
- C語言中的關(guān)鍵字 3次下載
- C語言內(nèi)嵌匯編 7次下載
- C語言和匯編語言混合編程方法和C語言中斷處理方法 36次下載
- C語言中指針的介紹非常詳細(xì) 57次下載
- MSP430 C語言編程的程序堆棧溢出分析
- c語言中從左到右結(jié)合怎么看 254次閱讀
- 介紹C語言中錯誤處理和異常處理的一些常用的方法和策略 465次閱讀
- C語言中結(jié)構(gòu)體能不能相加 1067次閱讀
- 如何給C語言中的函數(shù)定義兩個不同的名字? 547次閱讀
- 基于Rust語言中的生命周期 791次閱讀
- Rust語言中的反射機(jī)制 1961次閱讀
- C語言定義字符串的幾種方法 3337次閱讀
- C語言中的不完整類型是什么 1112次閱讀
- C語言中必須要掌握的位運算操作 1108次閱讀
- 在標(biāo)準(zhǔn)C語言中編譯出來的可執(zhí)行程序 1742次閱讀
- C語言中的goto語句怎么用?為什么反對使用 6505次閱讀
- C語言中變量和常量的關(guān)系 2768次閱讀
- C語言基礎(chǔ)語法之結(jié)構(gòu)體 3553次閱讀
- 在C語言中,如何分配浮點數(shù)的存儲方式? 8100次閱讀
- 基于C語言中指針的基本用法解析 4700次閱讀
下載排行
本周
- 1TC358743XBG評估板參考手冊
- 1.36 MB | 330次下載 | 免費
- 2開關(guān)電源基礎(chǔ)知識
- 5.73 MB | 6次下載 | 免費
- 3100W短波放大電路圖
- 0.05 MB | 4次下載 | 3 積分
- 4嵌入式linux-聊天程序設(shè)計
- 0.60 MB | 3次下載 | 免費
- 5基于FPGA的光纖通信系統(tǒng)的設(shè)計與實現(xiàn)
- 0.61 MB | 2次下載 | 免費
- 651單片機(jī)窗簾控制器仿真程序
- 1.93 MB | 2次下載 | 免費
- 751單片機(jī)大棚環(huán)境控制器仿真程序
- 1.10 MB | 2次下載 | 免費
- 8基于51單片機(jī)的RGB調(diào)色燈程序仿真
- 0.86 MB | 2次下載 | 免費
本月
- 1OrCAD10.5下載OrCAD10.5中文版軟件
- 0.00 MB | 234315次下載 | 免費
- 2555集成電路應(yīng)用800例(新編版)
- 0.00 MB | 33564次下載 | 免費
- 3接口電路圖大全
- 未知 | 30323次下載 | 免費
- 4開關(guān)電源設(shè)計實例指南
- 未知 | 21549次下載 | 免費
- 5電氣工程師手冊免費下載(新編第二版pdf電子書)
- 0.00 MB | 15349次下載 | 免費
- 6數(shù)字電路基礎(chǔ)pdf(下載)
- 未知 | 13750次下載 | 免費
- 7電子制作實例集錦 下載
- 未知 | 8113次下載 | 免費
- 8《LED驅(qū)動電路設(shè)計》 溫德爾著
- 0.00 MB | 6653次下載 | 免費
總榜
- 1matlab軟件下載入口
- 未知 | 935054次下載 | 免費
- 2protel99se軟件下載(可英文版轉(zhuǎn)中文版)
- 78.1 MB | 537796次下載 | 免費
- 3MATLAB 7.1 下載 (含軟件介紹)
- 未知 | 420026次下載 | 免費
- 4OrCAD10.5下載OrCAD10.5中文版軟件
- 0.00 MB | 234315次下載 | 免費
- 5Altium DXP2002下載入口
- 未知 | 233046次下載 | 免費
- 6電路仿真軟件multisim 10.0免費下載
- 340992 | 191185次下載 | 免費
- 7十天學(xué)會AVR單片機(jī)與C語言視頻教程 下載
- 158M | 183279次下載 | 免費
- 8proe5.0野火版下載(中文版免費下載)
- 未知 | 138040次下載 | 免費
評論
查看更多