java堆內(nèi)存溢出 java中為什么分棧內(nèi)存和堆內(nèi)存?
java中為什么分棧內(nèi)存和堆內(nèi)存?在Java中,堆棧內(nèi)存用于存儲函數(shù)的主體和變量名。Java中的代碼在函數(shù)體中執(zhí)行,每個函數(shù)體都放在堆棧內(nèi)存中,比如主函數(shù)。添加main函數(shù)并調(diào)用其他函數(shù),如Add()
java中為什么分棧內(nèi)存和堆內(nèi)存?
在Java中,堆棧內(nèi)存用于存儲函數(shù)的主體和變量名。Java中的代碼在函數(shù)體中執(zhí)行,每個函數(shù)體都放在堆棧內(nèi)存中,比如主函數(shù)。添加main函數(shù)并調(diào)用其他函數(shù),如Add()。然后在堆棧中的存儲主要是在底部和上面添加面。堆棧的運行時是后進先出的,所以當(dāng)它被執(zhí)行時,add將首先被銷毀,然后main將被銷毀。在Java中,堆內(nèi)存用于存儲實例。例如,main函數(shù)聲明了一個類perof people,people per;這個per在實例化之后存儲在堆棧內(nèi)存中(per=new people());instance之后的對象實體存儲在堆內(nèi)存中。存儲在堆棧內(nèi)存中的per存儲指向堆內(nèi)存的地址。堆內(nèi)存的存在是為了更好地管理內(nèi)存和實現(xiàn)垃圾回收。當(dāng)per不再指向堆內(nèi)存中的實例時,垃圾收集機制將刪除堆內(nèi)存中的new people()實例以釋放內(nèi)存。
JVM堆內(nèi)存中,為何有兩個survivor區(qū),一個不行嗎?
年輕一代使用復(fù)制算法。每次執(zhí)行小GC時,伊甸園區(qū)域中幸存的物體都會被復(fù)制到幸存區(qū)域,幸存的物體會被移到老年。如果只有一個幸存者區(qū)域,它將產(chǎn)生垃圾碎片。
讓我們看看只有一個s區(qū)域的情況
如果有兩個區(qū)域,一個是S1,一個是S2,則將S1和Eden區(qū)域的幸存對象復(fù)制到S2,下次觸發(fā)時將S2和Eden區(qū)域的幸存對象復(fù)制到S1