色婷婷AⅤ一区二区三区|亚洲精品第一国产综合亚AV|久久精品官方网视频|日本28视频香蕉

          新聞中心

          EEPW首頁(yè) > 嵌入式系統(tǒng) > 設(shè)計(jì)應(yīng)用 > 堆棧入門(mén)——堆和棧區(qū)別

          堆棧入門(mén)——堆和棧區(qū)別

          作者: 時(shí)間:2016-11-27 來(lái)源:網(wǎng)絡(luò) 收藏
          在計(jì)算機(jī)領(lǐng)域,是一個(gè)不容忽視的概念,我們編寫(xiě)的C語(yǔ)言程序基本上都要用到。但對(duì)于很多的初學(xué)著來(lái)說(shuō),堆棧是一個(gè)很模糊的概念。堆棧:一種數(shù)據(jù)結(jié)構(gòu)、一個(gè)在程序運(yùn)行時(shí)用于存放的地方,這可能是很多初學(xué)者的認(rèn)識(shí),因?yàn)槲以?jīng)就是這么想的和匯編語(yǔ)言中的堆棧一詞混為一談。我身邊的一些編程的朋友以及在網(wǎng)上看帖遇到的朋友中有好多也說(shuō)不清堆棧,所以我想有必要給大家分享一下我對(duì)堆棧的看法,有說(shuō)的不對(duì)的地方請(qǐng)朋友們不吝賜教,這對(duì)于大家學(xué)習(xí)會(huì)有很大幫助。
          首先在數(shù)據(jù)結(jié)構(gòu)上要知道堆棧,盡管我們這么稱(chēng)呼它,但實(shí)際上堆棧是兩種數(shù)據(jù)結(jié)構(gòu):堆和棧。
          堆和棧都是一種數(shù)據(jù)項(xiàng)按序排列的數(shù)據(jù)結(jié)構(gòu)。
          我們先從大家比較熟悉的棧說(shuō)起吧,它是一種具有后進(jìn)先出性質(zhì)的數(shù)據(jù)結(jié)構(gòu),也就是說(shuō)后存放的先取,先存放的后取。這就如同我們要取出放在箱子里面底下的東西(放入的比較早的物體),我們首先要移開(kāi)壓在它上面的物體(放入的比較晚的物體)。而堆就不同了,堆是一種經(jīng)過(guò)排序的樹(shù)形數(shù)據(jù)結(jié)構(gòu),每個(gè)結(jié)點(diǎn)都有一個(gè)值。通常我們所說(shuō)的堆的數(shù)據(jù)結(jié)構(gòu),是指二叉堆。堆的特點(diǎn)是根結(jié)點(diǎn)的值最?。ɑ蜃畲螅?,且根結(jié)點(diǎn)的兩個(gè)子樹(shù)也是一個(gè)堆。由于堆的這個(gè)特性,常用來(lái)實(shí)現(xiàn)優(yōu)先隊(duì)列,堆的存取是隨意,這就如同我們?cè)趫D書(shū)館的書(shū)架上取書(shū),雖然書(shū)的擺放是有順序的,但是我們想取任意一本時(shí)不必像棧一樣,先取出前面所有的書(shū),書(shū)架這種機(jī)制不同于箱子,我們可以直接取出我們想要的書(shū)。
          然而我要說(shuō)的重點(diǎn)并不在這,我要說(shuō)的堆和棧并不是數(shù)據(jù)結(jié)構(gòu)的堆和棧,之所以要說(shuō)數(shù)據(jù)結(jié)構(gòu)的堆和棧是為了和后面我要說(shuō)的堆區(qū)和棧區(qū)區(qū)別開(kāi)來(lái),請(qǐng)大家一定要注意。
          下面就說(shuō)說(shuō)C語(yǔ)言程序內(nèi)存分配中的堆和棧,這里有必要把內(nèi)存分配也提一下,大家不要嫌我啰嗦,一般情況下程序存放在Rom或Flash中,運(yùn)行時(shí)需要拷到內(nèi)存中執(zhí)行,內(nèi)存會(huì)分別存儲(chǔ)不同的信息,如下圖所示:

          內(nèi)存中的棧區(qū)處于相對(duì)較高的地址以地址的增長(zhǎng)方向?yàn)樯系脑?huà),棧地址是向下增長(zhǎng)的,棧中分配局部變量空間,堆區(qū)是向上增長(zhǎng)的用于分配程序員申請(qǐng)的內(nèi)存空間。另外還有靜態(tài)區(qū)是分配靜態(tài)變量,全局變量空間的;只讀區(qū)是分配常量和程序代碼空間的;以及其他一些分區(qū)。

          本文引用地址:http://cafeforensic.com/article/201611/322127.htm

          來(lái)看一個(gè)網(wǎng)上很流行的經(jīng)典例子:
          main.cpp
            int a = 0; 全局初始化區(qū)
            char *p1; 全局未初始化區(qū)
            main()
            {
            int b; 棧
            char s[] = "abc"; 棧
            char *p2; 棧
            char *p3 = "123456"; 123456