java對象的內存分配編輯與寄存器 、堆棧、堆、靜態存儲等

java對象的內存分配編輯
(1) 寄存器(register)。這是最快的保存區域,這是主要由於它位於處理器內部。然而,寄存器的數量十分有限,所以寄存器是需要由編譯器分配的。我們對此沒有直接的控制權,也不可能在自己的程序裏找到寄存器存在的任何蹤跡。
(2) 堆棧(stack)。位於通用RAM(隨機訪問存儲器)中。可通過它的“堆棧指針” 獲得處理的直接支持。堆棧指針若向下移,會創建新的內存;若向上移,則會釋放那些內存。這是一種特別快、特別有效的數據保存方式,僅次於寄存器。
創建程序時,Java編譯器必須準確地知道堆棧內保存的所有數據的“長度”以及“存在時間” 。
這是由於它必須生成相應的代碼,以便向上和向下移動指針。這一限制無疑影響了程序的靈活性,所以儘管有些Java 數據要保存在堆棧裏— — 特別是對象句柄(也稱對象的引用),但Java對象並不放到其中。
(3) 堆(heap)。一種通用性的內存池(也在RAM區域),其中保存了Java對象。和堆棧不同的是,“內存堆”或“堆”(Heap )最吸引人的地方在於編譯器不必知道要從堆裏分配多少存儲空間,也不必知道存儲的數據要在堆裏停留多長的時間。因此,用堆保存數據時會得到更大的靈活性。要求創建一個對象時,只需用new 命令編制相關的代碼即可。執行這些代碼時,會在堆裏自動進行數據的保存。當然,爲達到這種靈活性,必然會付出一定的代價。在堆裏分配存儲空間時會花掉更長的時間!
(4) 靜態存儲(static storage)。這的“靜態”(Static)是指“位於固定位置"(儘管也在RAM 裏)。程序運行期間,靜態存儲的數據將隨時等候調用。可用static關鍵字指出一個對象的特定元素是靜態的。但Java 對象本身永遠都不會置入靜態存儲空間。
(5) 常數存儲(constant storage)。常數值通常直接置於程序代碼內部。這樣做是安全的,因爲它們永遠都不會改變。
(6) 非RAM 存儲(non-storage-RAM)。若數據完全獨立於一個程序之外,則程序不運行時仍可存在,並在程序的控制範圍之外。其中兩個最主要的例子便是“ 流式對象”和“固定對象” 。對於流式對象,對象會變成字節流,通常會發給另一臺機器。而對於固定對象,對象保存在磁盤中。即使程序中止運行,它們仍可保持自己的狀態不變。對於這些類型的數據存儲,一個特別有用的技巧就是它們能存在於其他媒體中。一旦需要,甚至能將它們恢復成普通的、基於RAM的對象。Java 1.1提供了對輕量級持久化(Lightweight persistence)的支持。未來的版本甚至可能提供更完整的方案。
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章