鑒於網上對Java的堆棧區分,眾說紛紜,有的把C++的堆棧也混進來,有的沒有分清Stack,Heap的中文翻譯,搞得我把Stack當作堆,Heap當作棧,混亂了。昨天參加一外企的筆試,選擇英文答案時,選錯了,知道答案是堆,卻選擇了Stack。今天,決定把兩者區分清楚。
首先分清楚Stack,Heap的中文翻譯:Stack—棧,Heap—堆。
在中文裡,Stack可以翻譯為“堆棧”,所以我直接尋找了電腦術語裡面堆和棧開頭的詞語:
堆儲存: heapstorage 堆儲存分配: heapstorage allocation 堆儲存管理: heap storage management
棧編址: stack addressing 棧變換:stack transformation 棧儲存空間:stack memory 棧單元: stack cell
接著,總結在Java裡面Heap和Stack分別儲存資料的不同。
|
Heap(堆) |
Stack(棧) |
JVM中的功能 |
記憶體資料區 |
記憶體指令區 |
儲存資料 |
對象執行個體(1) |
基礎資料型別 (Elementary Data Type), 指令代碼,常量,對象的引用地址(2) |
1. 儲存對象執行個體,實際上是儲存對象執行個體的屬性值,屬性的類型和對象本身的類型標記等,並不儲存對象的方法(方法是指令,儲存在stack中)。
對象執行個體在heap中分配好以後,需要在stack中儲存一個4位元組的heap記憶體位址,用來定位該對象執行個體在heap中的位置,便於找到該對象執行個體。
2. 基礎資料型別 (Elementary Data Type)包括byte、int、char、long、float、double、boolean和short。
函數方法屬於指令.
=======================
引用網上廣泛流傳的“Java堆和棧的區別”裡面對堆和棧的介紹;
"Java 的堆是一個運行時資料區,類的(對象從中分配空間。這些對象通過new、newarray、anewarray和multianewarray等指令建立,它們不需要程式碼來顯式的釋放。堆是由記憶體回收來負責的,堆的優勢是可以動態地分配記憶體大小,生存期也不必事先告訴編譯器,因為它是在運行時動態分配記憶體的,Java的垃圾收集器會自動收走這些不再使用的資料。但缺點是,由於要在運行時動態分配記憶體,存取速度較慢。"
“棧的優勢是,存取速度比堆要快,僅次於寄存器,棧資料可以共用。但缺點是,存在棧中的資料大小與生存期必須是確定的,缺乏靈活性。棧中主要存放一些基本類型的變數(,int, short, long, byte, float, double, boolean, char)和物件控點。
”
可見,記憶體回收GC是針對堆Heap的,而棧因為本身是FILO - first in, last out. 先進後出,能夠自動釋放。 這樣就能明白到new建立的,都是放到堆Heap。