更新時(shí)間:2021-08-23 10:51:08 來(lái)源:動(dòng)力節(jié)點(diǎn) 瀏覽1094次
堆棧(英語(yǔ):stack)又稱為棧或堆疊,是計(jì)算機(jī)科學(xué)中一種特殊的串列形式的抽象數(shù)據(jù)類型,其特殊之處在于只能允許在鏈表或數(shù)組的一端(稱為堆棧頂端指針,英語(yǔ):top)進(jìn)行加入數(shù)據(jù)(英語(yǔ):push)和輸出數(shù)據(jù)(英語(yǔ):pop)的運(yùn)算。另外堆棧也可以用一維數(shù)組或鏈表的形式來(lái)完成。堆棧的另外一個(gè)相對(duì)的操作方式稱為隊(duì)列。
堆棧數(shù)據(jù)結(jié)構(gòu)使用兩種基本操作:推入(壓棧,push)和彈出(彈棧,pop):
推入:將數(shù)據(jù)放入堆棧的頂端(數(shù)組形式或串列形式),堆棧頂端top指針加一。
彈出:將頂端數(shù)據(jù)數(shù)據(jù)輸出(回傳),堆棧頂端數(shù)據(jù)減一。
堆(英語(yǔ):Heap)是計(jì)算機(jī)科學(xué)中的一種特別的樹(shù)狀數(shù)據(jù)結(jié)構(gòu)。若是滿足以下特性,即可稱為堆:“給定堆中任意節(jié)點(diǎn) P 和 C,若 P 是 C 的父節(jié)點(diǎn),那么 P 的值會(huì)小于等于(或大于等于) C 的值”。若父節(jié)點(diǎn)的值恒小于等于子節(jié)點(diǎn)的值,此堆稱為最小堆(英語(yǔ):min heap);反之,若父節(jié)點(diǎn)的值恒大于等于子節(jié)點(diǎn)的值,此堆稱為最大堆(英語(yǔ):max heap)。在堆中最頂端的那一個(gè)節(jié)點(diǎn),稱作根節(jié)點(diǎn)(英語(yǔ):root node),根節(jié)點(diǎn)本身沒(méi)有父節(jié)點(diǎn)(英語(yǔ):parent node)。
在java中堆一般用來(lái)存儲(chǔ)對(duì)象和數(shù)組,棧一般用來(lái)存儲(chǔ)方法和基本類型(注:基本類型不包括string)變量。
棧的存取速度比堆快。棧中的數(shù)據(jù)是可以共享的(解釋:比如int a = 3; int b =3; 此時(shí)b的指針直接指向3的地址即可,不用重新開(kāi)辟一塊空間存儲(chǔ)3的地址)
以上就是動(dòng)力節(jié)點(diǎn)小編介紹的"堆棧的概念及區(qū)別",希望對(duì)大家有幫助,想了解更多可查看Java堆棧。動(dòng)力節(jié)點(diǎn)在線學(xué)習(xí)教程,針對(duì)沒(méi)有任何Java基礎(chǔ)的讀者學(xué)習(xí),讓你從入門到精通,主要介紹了一些Java基礎(chǔ)的核心知識(shí),讓同學(xué)們更好更方便的學(xué)習(xí)和了解Java編程,感興趣的同學(xué)可以關(guān)注一下。
0基礎(chǔ) 0學(xué)費(fèi) 15天面授
有基礎(chǔ) 直達(dá)就業(yè)
業(yè)余時(shí)間 高薪轉(zhuǎn)行
工作1~3年,加薪神器
工作3~5年,晉升架構(gòu)
提交申請(qǐng)后,顧問(wèn)老師會(huì)電話與您溝通安排學(xué)習(xí)
初級(jí) 202925
初級(jí) 203221
初級(jí) 202629
初級(jí) 203743