棧空間用于存儲函數參數和局部變量,所需空間由系統自動分配,回收也由系統管理,無需人工干預;堆空間用于存儲動態分配的內存塊,分配和釋放空間均由程序員控制,有可能產生內存泄漏。
棧空間作為一個嚴格后進先出的數據結構,可用空間永遠都是一塊連續的區域;對空間在不斷分配和釋放空間的過程中,可用空間鏈表頻繁更新,造成可用空間逐漸碎片化,每塊可用空間都很小。
棧空間的默認大小只有幾M的空間,生長方式是向下的,也就是向著內存地址減小的方向消耗空間;堆空間的理論大小與幾G的空間,生長方式是向上的,也就是向著內存地址增大的方向消耗空間。
棧空間有計算機底層的支持,壓棧和出棧都有專門的指令,效率較高;堆空間通過函數動態獲取空間,涉及可用空間鏈表的掃描和調整以及相鄰可用空間的合并等操作,效率相對較低。
轉:https://blog.csdn.net/zrh_CSDN/article/details/80959053 ?