ios開發(fā)用什么編程語(yǔ)言 java中while(true)死循環(huán)會(huì)造成JVM內(nèi)存溢出嗎?
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
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)題,請(qǐng)指出)如果錯(cuò)誤)。
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ì)象。
jvm內(nèi)存溢出和內(nèi)存泄漏的區(qū)別?
當(dāng)對(duì)象未被引用時(shí),它將在垃圾收集期間自動(dòng)恢復(fù)。內(nèi)存泄漏:存在對(duì)該對(duì)象的引用,但沒(méi)有代碼邏輯使用該對(duì)象,例如:public class a{public static void main(string[]args){tobject P=new object()-tobject a=new object()-ta=P//a表示P的對(duì)象實(shí)例,TP=null//P為空時(shí),對(duì)象實(shí)例未被回收,因?yàn)檎谝?系統(tǒng)輸出打?。╝) //這里是值}}如果在下面的代碼中沒(méi)有使用對(duì)象實(shí)例,則該對(duì)象實(shí)例被視為內(nèi)存泄漏。直到a為空或引用了其他實(shí)例。(事實(shí)上,最好使用a的屬性來(lái)表示P)是內(nèi)存溢出嗎?很簡(jiǎn)單:一個(gè)映射會(huì)不斷地填滿對(duì)象,如果超過(guò)限制內(nèi)存就會(huì)溢出
JVM中的內(nèi)存和計(jì)算機(jī)中的內(nèi)存不一樣。JVM(Java虛擬機(jī))只是一個(gè)運(yùn)行在服務(wù)器上的進(jìn)程,它只占用部分內(nèi)存,堆通常占整個(gè)JVM內(nèi)存的80%以上
!JVM內(nèi)存溢出的可能情況有哪些?
可能原因1:最大堆內(nèi)存集太??!解決方案:通過(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)注。。