【Java基礎】——記憶體結構

來源:互聯網
上載者:User

關於Java的記憶體結構網上沒有統一的說法,但是內容大致相同,核心說法一樣就沒什麼問題了。

Java的記憶體劃分為五個區:

1. Heap(堆):執行個體分配的地方,通過-Xms與-Xmx來設定
2. MethodArea(方法地區):類的資訊及靜態變數。 對應是Permanet Generation, 通過-XX:PermSize來設定
3. JavaStack(java的棧):虛擬機器只會直接對Javastack執行兩種操作:以幀為單位的壓棧或出棧。通過-Xss來設定, 若不夠會拋出StackOverflowError
4. ProgramCounter(程式計數器):每一個線程都有它自己的PC寄存器,也是該線程啟動時建立的。PC寄存器的內容總是指向下一條將被執行指令的餓地址,這裡的地址可以是一個本地指標,也可以是在方法區中相對應於該方法起始指令的位移量。
5. Nativemethodstack(本地方法棧):儲存native方法進入地區的地址

其實我們最主要的還是討論堆記憶體棧記憶體

堆記憶體用來存放由 new 建立的對象和數組,在堆中分配的記憶體,由 JAVA 虛擬機器的自動記憶體回收行程來管理。在堆中產生了一個數組或者對象之後,還可以在棧中定義一個特殊的變數,讓棧中的這個變數的取值等於數組或對象在堆記憶體中的 首地址,棧中的這個變數就成了數組或對象的引用變數,以後就可以在程式中使用棧中的引用變數來訪問堆中的數組或者對象,引用變數就相當於是為數組或者對象
起的一個名稱。引用變數是普通的變數,定義時在棧中分配,引用變數在程式運行到其範圍之外後被釋放。而數組和對象本身在堆中分配,即使程式運行到使用 new 產生數組或者對象的語句所在的代碼塊之外,數組和對象本身佔據的記憶體不會被釋放,數組和對象在沒有引用變數指向它的時候,才變為垃圾,不能在被使用,但仍 然佔據記憶體空間不放,在隨後的一個不確定的時間被記憶體回收行程收走(釋放掉)。

在函數中定義的一些基本類型的變數和對象的引用變數都是在函數的棧記憶體中分配,當在一段代碼塊定義一個 變數時,Java 就在棧中為這個變數分配記憶體空間,當超過變數的範圍後,Java 會自動釋放掉為該變數分配的記憶體空間,該記憶體空間可以立即被另作它用。

是不是有的同學還是沒有弄懂什麼是堆記憶體什麼是棧記憶體?
其實很好記:
new出來對象的就存放在堆(對象)記憶體中
基礎資料類型就存放在棧記憶體中
=================================================        
PS:這段解釋略有點誤人子弟,具體堆記憶體與棧記憶體配置分析詳見【Java基礎——數組】

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.