中堆和棧的區別?
一、堆棧空間分配區別: 1、棧(操作系統):由操作系統自動分配釋放 ,存放函數的參數值,局部變量的值等。其操作方式類似于數據結構中的棧; 2、堆(操作系統): 一般由https://www.b5b6.com分配釋放, 若https://www.b5b6.com不釋放,程序結束時可能由OS回收,分配方式倒是類似于鏈表。 二、堆棧緩存方式區別: 1、棧使用的是一級緩存, 他們通常都是被調用時處于存儲空間中,調用完畢立即釋放; 2、堆是存放在二級緩存中,生命周期由虛擬機的垃圾回收算法來決定(并不是一旦成為孤兒對象就能被回收)。所以調用這些對象的速度要相對來得低一些。 三、堆棧數據結構區別: 堆(數據結構):堆可以被看成是一棵樹,如:堆排序; 棧(數據結構):一種先進后出的數據結構。