JVM主要管理兩種類(lèi)型內(nèi)存:堆和非堆李破,堆內(nèi)存(HeapMemory)是在Java虛擬機(jī)啟動(dòng)時(shí)創(chuàng)建,非堆內(nèi)存(Non-heapMemory)是在JVM堆之外的內(nèi)存壹将。
非堆包含方法區(qū)嗤攻、JVM內(nèi)部處理或優(yōu)化所需的內(nèi)存、每個(gè)類(lèi)結(jié)構(gòu)(如運(yùn)行時(shí)常數(shù)池诽俯、字段和方法數(shù)據(jù))以及方法和構(gòu)造方法的代碼妇菱。
堆是一個(gè)運(yùn)行時(shí)數(shù)據(jù)區(qū),類(lèi)的(對(duì)象從中分配空間。這些對(duì)象通過(guò)new暴区、newarray闯团、anewarray和multianewarray等指令建立,它們不需要程序代碼來(lái)顯式的釋放仙粱。堆是由垃圾回收來(lái)負(fù)責(zé)的房交,堆的優(yōu)勢(shì)是可以動(dòng)態(tài)地分配內(nèi)存大小,生存期也不必事先告訴編譯器伐割,因?yàn)樗窃谶\(yùn)行時(shí)動(dòng)態(tài)分配內(nèi)存的候味,Java的垃圾收集器會(huì)自動(dòng)收走這些不再使用的數(shù)據(jù)。但缺點(diǎn)是隔心,由于要在運(yùn)行時(shí)動(dòng)態(tài)分配內(nèi)存白群,存取速度較慢。
棧的優(yōu)勢(shì)是硬霍,存取速度比堆要快帜慢,僅次于寄存器,棧數(shù)據(jù)可以共享。但缺點(diǎn)是崖堤,存在棧中的數(shù)據(jù)大小與生存期必須是確定的侍咱,缺乏靈活性耐床。棧中主要存放一些基本類(lèi)型的變量數(shù)據(jù)(int,short,long,byte,float,double,boolean,char)和對(duì)象句柄(引用)密幔。
虛擬機(jī)必須為每個(gè)被裝載的類(lèi)型維護(hù)一個(gè)常量池。常量池就是該類(lèi)型所用到常量的一個(gè)有序集合撩轰,包括直接常量(string,integer和floatingpoint常量)和對(duì)其他類(lèi)型胯甩,字段和方法的符號(hào)引用。
對(duì)于String常量堪嫂,它的值是在常量池中的。而JVM中的常量池在內(nèi)存當(dāng)中是以表的形式存在的,對(duì)于String類(lèi)型拒担,有一張固定長(zhǎng)度的CONSTANT_String_info表用來(lái)存儲(chǔ)文字字符串值追驴,注意:該表只存儲(chǔ)文字字符串值,不存儲(chǔ)符號(hào)引用恶复。說(shuō)到這里怜森,對(duì)常量池中的字符串值的存儲(chǔ)位置應(yīng)該有一個(gè)比較明了的理解了。在程序執(zhí)行的時(shí)候,常量池會(huì)儲(chǔ)存在MethodArea,而不是堆中谤牡。常量池中保存著很多String對(duì)象;并且可以被共享使用副硅,因此它提高了效率。