一個線程占多少內(nèi)存 java一個線程占多少內(nèi)存?
java一個線程占多少內(nèi)存?不可能知道線程的內(nèi)存占用情況,因為它是共享內(nèi)存。限制每個線程占用的內(nèi)存,避免用戶查詢大量數(shù)據(jù)時出現(xiàn)Java內(nèi)存不足錯誤。進(jìn)程可以控制,但線程不能控制。您只能增加參數(shù)Xmx
java一個線程占多少內(nèi)存?
不可能知道線程的內(nèi)存占用情況,因為它是共享內(nèi)存。限制每個線程占用的內(nèi)存,避免用戶查詢大量數(shù)據(jù)時出現(xiàn)Java內(nèi)存不足錯誤。進(jìn)程可以控制,但線程不能控制。您只能增加參數(shù)Xmx XMS,或優(yōu)化程序。
java中while(true)死循環(huán)會造成JVM內(nèi)存溢出嗎?
1. 在死循環(huán)中定義局部變量會導(dǎo)致堆棧溢出,例如以下定義:
while(true){
int x=1;
int arr[]=New int[10];
}]因為堆棧空間存儲局部變量、參數(shù)和其他對象,所以堆棧有一個默認(rèn)深度,我記得是128M(內(nèi)存問題,請指出)如果錯誤)。
2. 在啟動循環(huán)中定義對象會導(dǎo)致堆內(nèi)存溢出,如以下定義:
(true){
person P=new person()
}
對象的生成會占用時間和空間,因為內(nèi)存空間有限,遲早會導(dǎo)致堆內(nèi)存溢出。
所以我們寫代碼是為了養(yǎng)成一個好習(xí)慣,不在特殊情況下,不在循環(huán)中定義局部變量和對象。