當我們運行程式時,作業系統會分配內存,以便該應用程式可以根據需要存儲資料並檢索資料。與C 或C++ 中程式設計師可以自由地「手動」分配記憶體和管理指標不同,在Java 中,JVM(Java 虛擬機)管理易失性存儲,為我們在兩個分配系統(堆和記憶體)中抽象了這種複雜性。堆疊。
它們之間的區別在於儲存的目的以及是否需要與多個進程共享資料。
JVM 使用堆疊來儲存短期資料並遵循 LIFO(後進先出)結構。堆疊是一個記憶體區域,用於管理方法的執行,在幀中以有組織的方式儲存局部變數和方法呼叫。 JVM 中的每個執行緒都有自己的堆疊。
堆是所有執行緒之間共享的全域記憶體區域,其中分配的物件和變數的使用壽命需要超出建立它們的方法的範圍。
堆上的記憶體由垃圾收集器管理,它會刪除未引用的物件以釋放空間,用於長期資料。
讓我們用一個實際的例子。
當在方法範圍內建立原始變數時,它必須在方法執行時可供使用。這樣,堆疊將儲存該變量,因為它負責在程式中具有獨特且特定用途的資料的生命週期。
但是,當方法建立實例時,該物件可以在程式的其他部分使用,而不僅僅是在聲明它的地方。當我們建立一個代表資料庫中記錄的物件時,這顯然會發生。在我們的程式中,可以在整個執行過程中查閱、編輯和刪除相同實例。這樣,堆將負責儲存物件。
為了說明這一點,我將使用作者 Hanumant Deshmukh 在他的指南「OCP Java SE 17/21 程式設計師考試基礎」中描述的一個簡單範例。順便說一句,這本書很棒,因為它在解釋相當複雜的過程方面非常具有說教性。如果您像我一樣正在尋找 Oracle 認證專家 (OCP) 認證,我強烈推薦您。作者使用 String 實例用於教學目的,但我將在這裡使用自訂物件只是為了避免侵犯版權的風險 (:S)
public class Main { public static void main(String[] args) { HeapObj heapObject = newObject(); int counter = 0; while (counter++ < 10){ print(heapObject.getName()); } } public static HeapObj newObject(){ return new HeapObj("Happy instance"); } public static void print(String text){ System.out.println(text); } }
在範例中,Main 類別呼叫三個方法:main 方法,一個建立 HeapObj 物件的實例,另一個僅列印文字。
如果我們在所有方法都已被呼叫時拍照,堆疊和堆疊將如下所示:
換句話說:
Stack:主框架(包含args、heapObject、計數器)。
堆:空。
堆疊:主框架(包含參數、heapObject 參考、計數器)。
Heap:帶有字串「Happy instance」的 HeapObj 物件。
Stack:主框架(包含args、heapObject參考、計數器),堆疊和未堆疊的多個列印幀。
堆:相同的 HeapObj 物件和字串“Happy instance”。
Stack:主框架(包含args、heapObject引用)。
堆:相同的 HeapObj 物件和字串“Happy instance”。
堆疊:空。
堆:空。
以上是堆疊與堆疊:Java 如何管理要記住或忘記的內容的詳細內容。更多資訊請關注PHP中文網其他相關文章!