c語(yǔ)言中堆和棧的區(qū)別 C語(yǔ)言中堆和棧的區(qū)別?
C語(yǔ)言中堆和棧的區(qū)別?在數(shù)據(jù)結(jié)構(gòu)中,堆和棧的原理幾乎是先入后出,但堆一般是一個(gè)二叉樹(shù),這是非線性的,比如堆排序。堆棧往往是線性的。堆和堆棧是C語(yǔ)言內(nèi)存管理的兩個(gè)不同部分。堆棧空間由操作系統(tǒng)管理、分配和
C語(yǔ)言中堆和棧的區(qū)別?
在數(shù)據(jù)結(jié)構(gòu)中,堆和棧的原理幾乎是先入后出,但堆一般是一個(gè)二叉樹(shù),這是非線性的,比如堆排序。堆棧往往是線性的。
堆和堆棧是C語(yǔ)言內(nèi)存管理的兩個(gè)不同部分。
堆??臻g由操作系統(tǒng)管理、分配和釋放。普通的局部變量存儲(chǔ)在堆棧上。
堆區(qū)域中的空間由用戶自己分配和管理。例如,每個(gè)malloc必須是自由的。否則操作系統(tǒng)不會(huì)為您發(fā)布它。
C語(yǔ)言還有一個(gè)代碼段,在程序執(zhí)行后不可寫(xiě),通常用于存儲(chǔ)常量。