內(nèi)存泄露和內(nèi)存溢出

1硼砰、內(nèi)存泄漏memory leak :是指程序在申請(qǐng)內(nèi)存后,無法釋放已申請(qǐng)的內(nèi)存空間欣硼,一次內(nèi)存泄漏似乎不會(huì)有大的影響,但內(nèi)存泄漏堆積后的后果就是內(nèi)存溢出恶阴。

2诈胜、內(nèi)存溢出 out of memory :指程序申請(qǐng)內(nèi)存時(shí),沒有足夠的內(nèi)存供申請(qǐng)者使用冯事,或者說焦匈,給了你一塊存儲(chǔ)int類型數(shù)據(jù)的存儲(chǔ)空間,但是你卻存儲(chǔ)long類型的數(shù)據(jù)昵仅,那么結(jié)果就是內(nèi)存不夠用缓熟,此時(shí)就會(huì)報(bào)錯(cuò)OOM,即所謂的內(nèi)存溢出。

3摔笤、二者的關(guān)系

內(nèi)存泄漏的堆積最終會(huì)導(dǎo)致內(nèi)存溢出

內(nèi)存溢出就是你要的內(nèi)存空間超過了系統(tǒng)實(shí)際分配給你的空間够滑,此時(shí)系統(tǒng)相當(dāng)于沒法滿足你的需求,就會(huì)報(bào)內(nèi)存溢出的錯(cuò)誤吕世。

內(nèi)存泄漏是指你向系統(tǒng)申請(qǐng)分配內(nèi)存進(jìn)行使用(new)彰触,可是使用完了以后卻不歸還(delete),結(jié)果你申請(qǐng)到的那塊內(nèi)存你自己也不能再訪問(也許你把它的地址給弄丟了)命辖,而系統(tǒng)也不能再次將它分配給需要的程序况毅。就相當(dāng)于你租了個(gè)帶鑰匙的柜子,你存完東西之后把柜子鎖上之后尔艇,把鑰匙丟了或者沒有將鑰匙還回去尔许,那么結(jié)果就是這個(gè)柜子將無法供給任何人使用,也無法被垃圾回收器回收终娃,因?yàn)檎也坏剿娜魏涡畔ⅰ?/p>

內(nèi)存溢出:一個(gè)盤子用盡各種方法只能裝4個(gè)果子味廊,你裝了5個(gè),結(jié)果掉倒地上不能吃了棠耕。這就是溢出毡们。比方說棧,棧滿時(shí)再做進(jìn)棧必定產(chǎn)生空間溢出昧辽,叫上溢衙熔,棧空時(shí)再做退棧也產(chǎn)生空間溢出搅荞,稱為下溢红氯。就是分配的內(nèi)存不足以放下數(shù)據(jù)項(xiàng)序列,稱為內(nèi)存溢出框咙。說白了就是我承受不了那么多,那我就報(bào)錯(cuò)痢甘,

4喇嘱、內(nèi)存泄漏的分類(按發(fā)生方式來分類)

常發(fā)性內(nèi)存泄漏。發(fā)生內(nèi)存泄漏的代碼會(huì)被多次執(zhí)行到塞栅,每次被執(zhí)行的時(shí)候都會(huì)導(dǎo)致一塊內(nèi)存泄漏者铜。

偶發(fā)性內(nèi)存泄漏。發(fā)生內(nèi)存泄漏的代碼只有在某些特定環(huán)境或操作過程下才會(huì)發(fā)生放椰。常發(fā)性和偶發(fā)性是相對(duì)的作烟。對(duì)于特定的環(huán)境,偶發(fā)性的也許就變成了常發(fā)性的砾医。所以測(cè)試環(huán)境和測(cè)試方法對(duì)檢測(cè)內(nèi)存泄漏至關(guān)重要拿撩。

一次性內(nèi)存泄漏。發(fā)生內(nèi)存泄漏的代碼只會(huì)被執(zhí)行一次如蚜,或者由于算法上的缺陷压恒,導(dǎo)致總會(huì)有一塊僅且一塊內(nèi)存發(fā)生泄漏。比如错邦,在類的構(gòu)造函數(shù)中分配內(nèi)存探赫,在析構(gòu)函數(shù)中卻沒有釋放該內(nèi)存,所以內(nèi)存泄漏只會(huì)發(fā)生一次撬呢。

隱式內(nèi)存泄漏期吓。程序在運(yùn)行過程中不停的分配內(nèi)存,但是直到結(jié)束的時(shí)候才釋放內(nèi)存倾芝。嚴(yán)格的說這里并沒有發(fā)生內(nèi)存泄漏讨勤,因?yàn)樽罱K程序釋放了所有申請(qǐng)的內(nèi)存。但是對(duì)于一個(gè)服務(wù)器程序晨另,需要運(yùn)行幾天潭千,幾周甚至幾個(gè)月,不及時(shí)釋放內(nèi)存也可能導(dǎo)致最終耗盡系統(tǒng)的所有內(nèi)存借尿。所以刨晴,我們稱這類內(nèi)存泄漏為隱式內(nèi)存泄漏。

5路翻、內(nèi)存溢出的原因及解決方法:

內(nèi)存溢出原因:

1.內(nèi)存中加載的數(shù)據(jù)量過于龐大狈癞,如一次從數(shù)據(jù)庫取出過多數(shù)據(jù);

2.集合類中有對(duì)對(duì)象的引用茂契,使用完后未清空蝶桶,使得JVM不能回收;

3.代碼中存在死循環(huán)或循環(huán)產(chǎn)生過多重復(fù)的對(duì)象實(shí)體掉冶;

4.使用的第三方軟件中的BUG真竖;

5.啟動(dòng)參數(shù)內(nèi)存值設(shè)定的過小

內(nèi)存溢出的解決方案:

第一步脐雪,修改JVM啟動(dòng)參數(shù),直接增加內(nèi)存恢共。(-Xms战秋,-Xmx參數(shù)一定不要忘記加。)

第二步讨韭,檢查錯(cuò)誤日志脂信,查看“OutOfMemory”錯(cuò)誤前是否有其 它異常或錯(cuò)誤透硝。

第三步狰闪,對(duì)代碼進(jìn)行走查和分析,找出可能發(fā)生內(nèi)存溢出的位置蹬铺。

重點(diǎn)排查以下幾點(diǎn):

1.檢查對(duì)數(shù)據(jù)庫查詢中,是否有一次獲得全部數(shù)據(jù)的查詢秉撇。一般來說甜攀,如果一次取十萬條記錄到內(nèi)存,就可能引起內(nèi)存溢出琐馆。這個(gè)問題比較隱蔽规阀,在上線前,數(shù)據(jù)庫中數(shù)據(jù)較少瘦麸,不容易出問題谁撼,上線后,數(shù)據(jù)庫中數(shù)據(jù)多了滋饲,一次查詢就有可能引起內(nèi)存溢出厉碟。因此對(duì)于數(shù)據(jù)庫查詢盡量采用分頁的方式查詢。

2.檢查代碼中是否有死循環(huán)或遞歸調(diào)用屠缭。

3.檢查是否有大循環(huán)重復(fù)產(chǎn)生新對(duì)象實(shí)體箍鼓。

4.檢查對(duì)數(shù)據(jù)庫查詢中,是否有一次獲得全部數(shù)據(jù)的查詢呵曹。一般來說款咖,如果一次取十萬條記錄到內(nèi)存,就可能引起內(nèi)存溢出奄喂。這個(gè)問題比較隱蔽铐殃,在上線前,數(shù)據(jù)庫中數(shù)據(jù)較少跨新,不容易出問題富腊,上線后,數(shù)據(jù)庫中數(shù)據(jù)多了域帐,一次查詢就有可能引起內(nèi)存溢出蟹肘。因此對(duì)于數(shù)據(jù)庫查詢盡量采用分頁的方式查詢词疼。

5.檢查List、MAP等集合對(duì)象是否有使用完后帘腹,未清除的問題贰盗。List、MAP等集合對(duì)象會(huì)始終存有對(duì)對(duì)象的引用阳欲,使得這些對(duì)象不能被GC回收舵盈。

第四步,使用內(nèi)存查看工具動(dòng)態(tài)查看內(nèi)存使用情況球化。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末秽晚,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子筒愚,更是在濱河造成了極大的恐慌赴蝇,老刑警劉巖,帶你破解...
    沈念sama閱讀 222,378評(píng)論 6 516
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件巢掺,死亡現(xiàn)場(chǎng)離奇詭異句伶,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)陆淀,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,970評(píng)論 3 399
  • 文/潘曉璐 我一進(jìn)店門考余,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人轧苫,你說我怎么就攤上這事楚堤。” “怎么了含懊?”我有些...
    開封第一講書人閱讀 168,983評(píng)論 0 362
  • 文/不壞的土叔 我叫張陵身冬,是天一觀的道長。 經(jīng)常有香客問我岔乔,道長吏恭,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 59,938評(píng)論 1 299
  • 正文 為了忘掉前任重罪,我火速辦了婚禮樱哼,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘剿配。我一直安慰自己搅幅,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 68,955評(píng)論 6 398
  • 文/花漫 我一把揭開白布呼胚。 她就那樣靜靜地躺著茄唐,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上沪编,一...
    開封第一講書人閱讀 52,549評(píng)論 1 312
  • 那天呼盆,我揣著相機(jī)與錄音,去河邊找鬼蚁廓。 笑死访圃,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的相嵌。 我是一名探鬼主播腿时,決...
    沈念sama閱讀 41,063評(píng)論 3 422
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼饭宾!你這毒婦竟也來了批糟?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,991評(píng)論 0 277
  • 序言:老撾萬榮一對(duì)情侶失蹤看铆,失蹤者是張志新(化名)和其女友劉穎徽鼎,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體弹惦,經(jīng)...
    沈念sama閱讀 46,522評(píng)論 1 319
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡否淤,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,604評(píng)論 3 342
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了肤频。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片叹括。...
    茶點(diǎn)故事閱讀 40,742評(píng)論 1 353
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡算墨,死狀恐怖宵荒,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情净嘀,我是刑警寧澤报咳,帶...
    沈念sama閱讀 36,413評(píng)論 5 351
  • 正文 年R本政府宣布,位于F島的核電站挖藏,受9級(jí)特大地震影響暑刃,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜膜眠,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 42,094評(píng)論 3 335
  • 文/蒙蒙 一岩臣、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧宵膨,春花似錦架谎、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,572評(píng)論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至捎琐,卻和暖如春会涎,著一層夾襖步出監(jiān)牢的瞬間裹匙,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,671評(píng)論 1 274
  • 我被黑心中介騙來泰國打工末秃, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留概页,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 49,159評(píng)論 3 378
  • 正文 我出身青樓蛔溃,卻偏偏與公主長得像绰沥,于是被迫代替她去往敵國和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子贺待,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,747評(píng)論 2 361

推薦閱讀更多精彩內(nèi)容