Java内存分配
通常Java內(nèi)存分配會涉及到以下幾個區(qū)域:
- 寄存器:在CPU內(nèi)部,通常開發(fā)人員不能通過代碼來控制的部分,主要是有編譯器自己來管理的
- 棧:存放基本類型的數(shù)據(jù)和對象的引用,對象本身不存放在棧中,而是存放在堆中
- 堆:存放對象,也就是通常在Java中new產(chǎn)生的數(shù)據(jù)
- 靜態(tài)區(qū)域:存放程序中定義的static的靜態(tài)成員
- 常量池:存放常量,如final定義的
- 非RAM存儲:硬盤等永久存儲空間,如持久化對象等等
對于理解Java中的內(nèi)存分配主要是棧(stack)和堆(heap)內(nèi)存
1、棧——stack
a、在棧中存放的是基本數(shù)據(jù)類型定義的變量以及對象的引用變量,比如:定義變量int a=3,b=3;定義對象引用String str ;HelloWorld hello;等這樣的數(shù)據(jù)都是存放棧內(nèi)存中
b、棧中存放的數(shù)據(jù)是可以共享的,如:int a = 1 ; int b = 1 ;這里不會對數(shù)據(jù)1存儲兩次,第二次定義的變量b的值所指向的變量a定義時的值1,如果b=2,那它會先遍歷棧中的所有數(shù)據(jù)是否有值1存在,如果沒有,那么它將重新申請一塊棧內(nèi)存資源來存放值2
c、棧的存取速度比堆要快,僅次于寄存器。
d、棧中的內(nèi)存是隨著作用區(qū)域來回收的,當(dāng)這個變量或者對象引用在這個作用范圍的代碼塊執(zhí)行結(jié)束之后就自動釋放了
缺點:存在棧中的數(shù)據(jù)大小與生存期必須是 確定的,缺乏靈活性。
2、堆——heap
a、堆內(nèi)存是用來存放由new創(chuàng)建的對象和數(shù)組的
b、堆中的內(nèi)存大小是動態(tài)分配的,所以它是運行時內(nèi)存,由Java GC自動回收。
如:
A a = new A();
通常辨別棧內(nèi)存和堆內(nèi)存,對于如上的這個表達(dá)式,=左邊的就是存放在棧內(nèi)存中,=右邊的就是存放堆內(nèi)存中。A a就是存在在棧內(nèi)存中的一個對象的引用,這個引用就是指向堆內(nèi)存中的new A()。
缺點:棧內(nèi)存是運行到作用范圍之外之后釋放掉內(nèi)存,而堆中的數(shù)組和對象,及時運行到所在的代碼塊之外,數(shù)組和對象本身占據(jù)的內(nèi)存是不會被釋放的,數(shù)組和對象在沒有引用變量指向它時,就變?yōu)槔?#xff0c;不能再被使用,但仍舊占據(jù)著內(nèi)存空間不放,在隨后一個不確定的時間被垃圾收集器回收走。所以這就是Java比較占內(nèi)存的原因。
備注:實際上,棧中的引用變量指向堆中的new對象,就是java中的指針。
總結(jié)
- 上一篇: ORA-25153: Temporary
- 下一篇: Java设计模式 创建模式-单态模式(S