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