您好,登錄后才能下訂單哦!
這篇文章主要介紹“java jvm 內存溢出和內存泄漏的區別是什么”,在日常操作中,相信很多人在java jvm 內存溢出和內存泄漏的區別是什么問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”java jvm 內存溢出和內存泄漏的區別是什么”的疑惑有所幫助!接下來,請跟著小編一起來學習吧!
內存溢出 out of memory
是指程序在申請內存時,沒有足夠的內存空間供其使用,出現 out of memory
。
比如申請了一個10MB 空間, 但是當前內存只有5MB,那就是內存溢出。
javadoc 對 OutOfMemoryError
的解釋是, 沒有空閑內存,垃圾收集器也無未能提供更多的內存空間 。
內存泄露 memory leak
是指程序運行結束后,沒有釋放已所占用的內存空間,一次內存泄漏 似乎不會有大的影響,但內存泄漏 堆積后的后果就是 內存溢出。
1)單例模式
單例的生命周期和應用程序是一樣長的,所以單例程序中如果持有對外部對象的引用的話,那么這個外部對象是不能被回收的,則會導致內存泄露的產生。
2)一些提供close的資源未閉導致內存泄漏
數據庫連接(dataSource.getConnection() ),網絡連接(socket)和 IO流的連接必須在finally中 close,否則不能被回收的。
內存溢出就是你要的內存空間超過了系統實際分配給你的空間,此時系統相當于沒法滿足你的需求,就會報內存溢出的錯誤。
內存溢出:一個盤子用盡各種方法只能裝4個果子,你裝了5個,結果掉倒地上不能吃了。這就是溢出。比方說棧,棧滿時再做進棧必定產生空間溢出,叫上溢,棧空時再做退棧也產生空間溢出,稱為下溢。就是分配的內存不足以放下數據項序列,稱為內存溢出。說白了就是我承受不了那么多,那我就報錯。
內存泄漏是指你向系統申請分配內存進行使用(new),可是使用完了以后卻不歸還(delete),結果你申請到的那塊內存你自己也不能再訪問(也許你把它的地址給弄丟了),而系統也不能再次將它分配給需要的程序。就相當于你租了個帶鑰匙的柜子,你存完東西之后把柜子鎖上之后,把鑰匙丟了或者沒有將鑰匙還回去,那么結果就是這個柜子將無法供給任何人使用,也無法被垃圾回收器回收,因為找不到他的任何信息。
內存泄漏的堆積最終會導致內存溢出。
引起內存溢出的原因有很多種,小編列舉一下常見的有以下幾種:
內存中加載的數據量過于龐大,如一次從數據庫取出過多數據;
集合類中有對對象的引用,使用完后未清空,使得JVM不能回收;
代碼中存在死循環或循環產生過多重復的對象實體;
使用的第三方軟件中的BUG;
啟動參數內存值設定的過小 。
第一步,修改JVM啟動參數,直接增加內存。(-Xms
、-Xmx
參數一定不要忘記加)
第二步,檢查錯誤日志,查看 “OutOfMemory” 錯誤前是否有其它異常或錯誤。
第三步,對代碼進行走查和分析,找出可能發生內存溢出的位置。
重點排查以下幾點:
1.檢查對數據庫查詢中,是否有一次獲得全部數據的查詢。
一般來說,如果一次取十萬條記錄到內存,就可能引起內存溢出。
這個問題比較隱蔽,在上線前,數據庫中數據較少,不容易出問題,上線后,
數據庫中數據多了,一次查詢就有可能引起內存溢出。因此對于數據庫查詢盡量采用分頁的方式查詢。
2.檢查代碼中是否有死循環或遞歸調用。
3.檢查是否有大循環重復產生新對象實體。
4.檢查對數據庫查詢中,是否有一次獲得全部數據的查詢。
一般來說,如果一次取十萬條記錄到內存,就可能引起內存溢出。
這個問題比較隱蔽,在上線前,數據庫中數據較少,不容易出問題,
上線后,數據庫中數據多了,一次查詢就有可能引起內存溢出。因此對于數據庫查詢盡量采用分頁的方式查詢。
5.檢查List、MAP等集合對象是否有使用完后,未清除的問題。
List、MAP等集合對象會始終存有對對象的引用,使得這些對象不能被GC回收。
第四步,使用內存查看工具動態查看內存使用情況。
到此,關于“java jvm 內存溢出和內存泄漏的區別是什么”的學習就結束了,希望能夠解決大家的疑惑。理論與實踐的搭配能更好的幫助大家學習,快去試試吧!若想繼續學習更多相關知識,請繼續關注億速云網站,小編會繼續努力為大家帶來更多實用的文章!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。