方法的重寫(xiě)與重載的區(qū)別 java程序死循環(huán)了怎么辦?
java程序死循環(huán)了怎么辦?首先,你需要找出哪個(gè)進(jìn)程被卡住了打開(kāi)控制器,輸入PS-EF命令找到相應(yīng)的java進(jìn)程,或者用top查看CPU占用率高的進(jìn)程,然后殺死該進(jìn)程。在編寫(xiě)程序時(shí),應(yīng)特別注意存在生死
java程序死循環(huán)了怎么辦?
首先,你需要找出哪個(gè)進(jìn)程被卡住了
打開(kāi)控制器,輸入PS-EF命令找到相應(yīng)的java進(jìn)程,或者用top查看CPU占用率高的進(jìn)程,然后殺死該進(jìn)程。
在編寫(xiě)程序時(shí),應(yīng)特別注意存在生死循環(huán)的地方,例如while(true)。盡量不要使用它們,或者添加一些控件,例如超時(shí)處理,或者使用多個(gè)線(xiàn)程等待和通知。這應(yīng)該是一個(gè)相對(duì)簡(jiǎn)單的處理方法。如果您需要更進(jìn)一步,您仍然需要根據(jù)業(yè)務(wù)使用判斷邏輯。此外,我們需要在后期上線(xiàn)之前測(cè)試覆蓋這些條件的方法。只有當(dāng)沒(méi)有死循環(huán)時(shí)才是合格的程序。
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)存溢出。
所以我們寫(xiě)代碼是為了養(yǎng)成一個(gè)好習(xí)慣,不在特殊情況下,不在循環(huán)中定義局部變量和對(duì)象。