java宿舍管理系統(tǒng) Java程序員是如何解決內(nèi)存溢出問(wèn)題的?
Java程序員是如何解決內(nèi)存溢出問(wèn)題的?java中while(true)死循環(huán)會(huì)造成JVM內(nèi)存溢出嗎?1。在死循環(huán)中定義局部變量會(huì)導(dǎo)致堆棧溢出,例如以下定義:while(true){int x=1;i
Java程序員是如何解決內(nèi)存溢出問(wèn)題的?
java中while(true)死循環(huán)會(huì)造成JVM內(nèi)存溢出嗎?
1。在死循環(huán)中定義局部變量會(huì)導(dǎo)致堆棧溢出,例如以下定義:
while(true){
int x=1;
int arr[]=New int[10];
}]因?yàn)槎褩?臻g存儲(chǔ)局部變量、參數(shù)和其他對(duì)象,所以堆棧有一個(gè)默認(rèn)深度,我記得是128M(內(nèi)存問(wèn)題,錯(cuò)誤,請(qǐng)指出)。
2. 在啟動(dòng)循環(huán)中定義對(duì)象會(huì)導(dǎo)致堆內(nèi)存溢出,如以下定義:
(true){
person P=new person()
}
對(duì)象的生成會(huì)占用時(shí)間和空間,因?yàn)閮?nèi)存空間有限,遲早會(huì)導(dǎo)致堆內(nèi)存溢出。
所以我們寫代碼是為了養(yǎng)成一個(gè)好習(xí)慣,不在特殊情況下,不在循環(huán)中定義局部變量和對(duì)象。
Java里還有大約20%可用內(nèi)存的情況下顯示內(nèi)存溢出,是怎么回事?應(yīng)該怎么辦?
JVM中的內(nèi)存與計(jì)算機(jī)的內(nèi)存不同。JVM(Java虛擬機(jī))只是一個(gè)在服務(wù)器上運(yùn)行的進(jìn)程,它只占用一部分內(nèi)存。堆通常占整個(gè)JVM內(nèi)存的80%
!JVM內(nèi)存溢出的可能情況有哪些?
可能原因1:最大堆內(nèi)存集太?。〗鉀Q方案:通過(guò)設(shè)置-Xmx來(lái)增加最大堆內(nèi)存
!可能原因:遞歸調(diào)用方法容易出現(xiàn)堆棧溢出
!解決方案:優(yōu)化代碼
!通常不會(huì)溢出,請(qǐng)使用-XX:permsize設(shè)置適當(dāng)?shù)挠谰蒙?/p>
!一直在不斷分享Java技術(shù),有需要的朋友請(qǐng)關(guān)注。。