日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術(shù)文章
文章詳情頁

Java虛擬機(jī)內(nèi)存溢出與內(nèi)存泄漏

瀏覽:213日期:2022-09-03 08:12:00

一、基本概念

內(nèi)存溢出:簡單地說內(nèi)存溢出就是指程序運(yùn)行過程中申請的內(nèi)存大于系統(tǒng)能夠提供的內(nèi)存,導(dǎo)致無法申請到足夠的內(nèi)存,于是就發(fā)生了內(nèi)存溢出。

內(nèi)存泄漏:內(nèi)存泄漏指程序運(yùn)行過程中分配內(nèi)存給臨時變量,用完之后卻沒有被GC回收,始終占用著內(nèi)存,既不能被使用也不能分配給其他程序,于是就發(fā)生了內(nèi)存泄漏。

內(nèi)存溢出 out of memory,是指程序在申請內(nèi)存時,沒有足夠的內(nèi)存空間供其使用,出現(xiàn)out of memory;

內(nèi)存泄露 memory leak,是指程序在申請內(nèi)存后,無法釋放已申請的內(nèi)存空間,一次內(nèi)存泄露危害可以忽略,但內(nèi)存泄露堆積后果很嚴(yán)重,無論多少內(nèi)存,遲早會被占光。

memory leak會最終會導(dǎo)致out of memory!

內(nèi)存泄露是指無用對象(不再使用的對象)持續(xù)占有內(nèi)存或無用對象的內(nèi)存得不到及時釋放,從而造成的內(nèi)存空間的浪費(fèi)稱為內(nèi)存泄露。內(nèi)存泄露有時不嚴(yán)重且不易察覺,這樣開發(fā)者就不知道存在內(nèi)存泄露,但有時也會很嚴(yán)重,會提示你Out of memory。

二、內(nèi)存溢出的常見情況

內(nèi)存溢出有以下幾種常見的情況:

1、java.lang.OutOfMemoryError: PermGen space (持久帶溢出)

我們知道jvm通過持久帶實(shí)現(xiàn)了java虛擬機(jī)規(guī)范中的方法區(qū),而運(yùn)行時常量池就是保存在方法區(qū)中的,因此發(fā)生這種溢出可能是運(yùn)行時常量池溢出,或是由于程序中使用了大量的jar或class,使得方法區(qū)中保存的class對象沒有被及時回收或者class信息占用的內(nèi)存超過了配置的大小。

2、java.lang.OutOfMemoryError: Java heap space (堆溢出)

發(fā)生這種溢出的原因一般是創(chuàng)建的對象太多,在進(jìn)行垃圾回收之前對象數(shù)量達(dá)到了最大堆的容量限制。

解決這個區(qū)域異常的方法一般是通過內(nèi)存映像分析工具對Dump出來的堆轉(zhuǎn)儲快照進(jìn)行分析,看到底是內(nèi)存溢出還是內(nèi)存泄漏。如果是內(nèi)存泄漏,可進(jìn)一步通過工具查看泄漏對象到GC Roots的引用鏈,定位出泄漏代碼的位置,修改程序或算法;如果不存在泄漏,就是說內(nèi)存中的對象確實(shí)都還必須存活,那就應(yīng)該檢查虛擬機(jī)的堆參數(shù)-Xmx(最大堆大小)和-Xms(初始堆大小),與機(jī)器物理內(nèi)存對比看是否可以調(diào)大。

3、虛擬機(jī)棧和本地方法棧溢出

如果線程請求的棧深度大于虛擬機(jī)所允許的最大深度,將拋出StackOverflowError。

如果虛擬機(jī)在擴(kuò)展棧時無法申請到足夠的內(nèi)存空間,則拋出OutOfMemoryError。

三、內(nèi)存泄漏

內(nèi)存泄漏的根本原因是長生命周期的對象持有短生命周期對象的引用,盡管短生命周期的對象已經(jīng)不再需要,但由于長生命周期對象持有它的引用而導(dǎo)致不能被回收。

以發(fā)生的方式來分類,內(nèi)存泄漏可以分為4類:

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

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

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

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

從用戶使用程序的角度來看,內(nèi)存泄漏本身不會產(chǎn)生什么危害,作為一般的用戶,根本感覺不到內(nèi)存泄漏的存在。真正有危害的是內(nèi)存泄漏的堆積,這會最終消耗盡系統(tǒng)所有的內(nèi)存。從這個角度來說,一次性內(nèi)存泄漏并沒有什么危害,因?yàn)樗粫逊e,而隱式內(nèi)存泄漏危害性則非常大,因?yàn)檩^之于常發(fā)性和偶發(fā)性內(nèi)存泄漏它更難被檢測到。

下面總結(jié)幾種常見的內(nèi)存泄漏:

1、靜態(tài)集合類引起的內(nèi)存泄漏:

像HashMap、Vector等的使用最容易出現(xiàn)內(nèi)存泄露,這些靜態(tài)變量的生命周期和應(yīng)用程序一致,他們所引用的所有的對象Object也不能被釋放,從而造成內(nèi)存泄漏,因?yàn)樗麄円矊⒁恢北籚ector等引用著。

Vector<Object> v=new Vector<Object>(100);for (int i = 1; i<100; i++){Object o = new Object();v.add(o);o = null;}

在這個例子中,循環(huán)申請Object 對象,并將所申請的對象放入一個Vector 中,如果僅僅釋放引用本身(o=null),那么Vector 仍然引用該對象,所以這個對象對GC 來說是不可回收的。因此,如果對象加入到Vector 后,還必須從Vector 中刪除,最簡單的方法就是將Vector對象設(shè)置為null。

2、修改HashSet中對象的參數(shù)值,且參數(shù)是計算哈希值的字段

當(dāng)一個對象被存儲到HashSet集合中以后,修改了這個對象中那些參與計算哈希值的字段后,這個對象的哈希值與最初存儲在集合中的就不同了,這種情況下,用contains方法在集合中檢索對象是找不到的,這將會導(dǎo)致無法從HashSet中刪除當(dāng)前對象,造成內(nèi)存泄漏,舉例如下:

public static void main(String[] args){ Set<Person> set = new HashSet<Person>(); Person p1 = new Person('張三','1',25); Person p2 = new Person('李四','2',26); Person p3 = new Person('王五','3',27); set.add(p1); set.add(p2); set.add(p3); System.out.println('總共有:'+set.size()+' 個元素!'); //結(jié)果:總共有:3 個元素! p3.setAge(2); //修改p3的年齡,此時p3元素對應(yīng)的hashcode值發(fā)生改變 set.remove(p3); //此時remove不掉,造成內(nèi)存泄漏 set.add(p3); //重新添加,可以添加成功 System.out.println('總共有:'+set.size()+' 個元素!'); //結(jié)果:總共有:4 個元素! for (Person person : set){ System.out.println(person); }}

3、監(jiān)聽器

在java 編程中,我們都需要和監(jiān)聽器打交道,通常一個應(yīng)用當(dāng)中會用到很多監(jiān)聽器,我們會調(diào)用一個控件的諸如addXXXListener()等方法來增加監(jiān)聽器,但往往在釋放對象的時候卻沒有記住去刪除這些監(jiān)聽器,從而增加了內(nèi)存泄漏的機(jī)會。

4、各種連接

比如數(shù)據(jù)庫連接(dataSourse.getConnection()),網(wǎng)絡(luò)連接(socket)和io連接,除非其顯式的調(diào)用了其close() 方法將其連接關(guān)閉,否則是不會自動被GC 回收的。對于Resultset 和Statement 對象可以不進(jìn)行顯式回收,但Connection 一定要顯式回收,因?yàn)镃onnection 在任何時候都無法自動回收,而Connection一旦回收,Resultset 和Statement 對象就會立即為NULL。但是如果使用連接池,情況就不一樣了,除了要顯式地關(guān)閉連接,還必須顯式地關(guān)閉Resultset Statement 對象(關(guān)閉其中一個,另外一個也會關(guān)閉),否則就會造成大量的Statement 對象無法釋放,從而引起內(nèi)存泄漏。這種情況下一般都會在try里面去連接,在finally里面釋放連接。

5、單例模式

如果單例對象持有外部對象的引用,那么這個外部對象將不能被jvm正常回收,導(dǎo)致內(nèi)存泄露。

不正確使用單例模式是引起內(nèi)存泄露的一個常見問題,單例對象在被初始化后將在JVM的整個生命周期中存在(以靜態(tài)變量的方式),如果單例對象持有外部對象的引用,那么這個外部對象將不能被jvm正常回收,導(dǎo)致內(nèi)存泄露,考慮下面的例子:

class A{ public A(){ B.getInstance().setA(this); } ....}//B類采用單例模式class B{ private A a; private static B instance=new B(); public B(){} public static B getInstance(){ return instance; } public void setA(A a){ this.a=a; } //getter...}

顯然B采用singleton模式,它持有一個A對象的引用,而這個A類的對象將不能被回收。想象下如果A是個比較復(fù)雜的對象或者集合類型會發(fā)生什么情況。

避免內(nèi)存泄漏的幾點(diǎn)建議:

1、盡早釋放無用對象的引用。

2、避免在循環(huán)中創(chuàng)建對象。

3、使用字符串處理時避免使用String,應(yīng)使用StringBuffer。

4、盡量少使用靜態(tài)變量,因?yàn)殪o態(tài)變量存放在永久代,基本不參與垃圾回收。

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持好吧啦網(wǎng)。

標(biāo)簽: Java
相關(guān)文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
日韩视频二区| 国产精品分类| 国产精品1区| 日韩在线电影| 国产免费av国片精品草莓男男| 国产麻豆一区二区三区精品视频| 国产精品成人自拍| av中文字幕在线观看第一页| 久久久夜夜夜| 亚洲一区二区三区无吗| 国产香蕉精品| 伊伊综合在线| 久久99伊人| 国产精品红桃| 欧美日中文字幕| 中文字幕av一区二区三区四区| 国产精品一区亚洲| 国内在线观看一区二区三区| 久久久久久久久丰满| 午夜亚洲福利在线老司机| 91国内精品| 中文字幕在线高清| 免费在线观看成人| 久久久国产精品入口麻豆| 欧美va天堂在线| 欧美日韩伊人| 久久久夜夜夜| 日本不卡视频在线| 日韩中文影院| 日韩欧美中文字幕在线视频| 麻豆精品国产91久久久久久| 亚洲欧洲一区| 国产乱码精品一区二区三区亚洲人 | 在线看片国产福利你懂的| 欧美成人精品| 国产毛片久久久| 激情综合网五月| 国产伦理久久久久久妇女| 在线成人直播| 激情久久99| 99国产精品视频免费观看一公开| 97久久亚洲| 欧美日韩激情| 国产精品免费精品自在线观看| 欧美午夜精彩| 美女久久精品| 日本亚洲欧美天堂免费| 91精品一区国产高清在线gif| 天堂精品久久久久| 一区二区小说| 麻豆精品在线视频| 一区二区电影在线观看| 日韩欧美中文| 国产精品久久久久77777丨| 国产视频一区三区| 久久影院午夜精品| 国产日韩一区二区三区在线 | 日本精品久久| 蜜桃tv一区二区三区| 久久亚洲国产精品尤物| 亚洲3区在线| 国产精品普通话对白| 日韩欧美二区| 国产精品99视频| 国产精品红桃| 日本午夜精品一区二区三区电影 | 麻豆成人综合网| 日韩精品高清不卡| 久久免费黄色| 91视频精品| 久久精品国产精品亚洲毛片| 日韩欧美中文字幕电影| 国产精品婷婷| 九九综合九九| 久久中文亚洲字幕| 欧洲精品一区二区三区| 国产一区二区视频在线看| 欧美精品福利| 欧美日韩夜夜| 91精品国产自产在线丝袜啪| 六月婷婷一区| 国产毛片一区| 野花国产精品入口| 亚洲手机在线| 九九精品调教| 久久久国产亚洲精品| 91亚洲人成网污www| 国产精品流白浆在线观看| 欧美自拍一区| 青青青国产精品| 国产人成精品一区二区三| 91麻豆精品激情在线观看最新| 亚洲免费观看高清完整版在线观| 日韩制服丝袜av| 中文字幕一区二区av| 一级欧美视频| 日韩精品国产欧美| 欧美久久亚洲| 国产日韩视频在线| 国产亚洲一区二区三区啪| 久久国产精品色av免费看| 国产亚洲高清一区| 久久精品国产999大香线蕉| 手机在线电影一区| 成人羞羞在线观看网站| 精品一区在线| 久久午夜视频| 日韩av不卡一区二区| 久久激情五月婷婷| 久久只有精品| 久久久久中文| 久热精品在线| 欧美日韩黄网站| 福利一区和二区| 亚洲综合电影| 国精品一区二区| 免费不卡在线观看| 国产精品最新自拍| 粉嫩av一区二区三区四区五区 | 蜜臀a∨国产成人精品| 亚洲毛片网站| 欧美国产不卡| 在线日韩中文| 日韩**一区毛片| 卡一卡二国产精品| 国产精品亚洲一区二区三区在线观看| 欧美+日本+国产+在线a∨观看| 视频一区二区三区在线| 青青草精品视频| 91视频久久| 国产一区白浆| 国产精品高清一区二区| 亚洲成人精品| 青青草伊人久久| 三级小说欧洲区亚洲区| 亚洲三级毛片| 国产精品xx| 蜜臀精品久久久久久蜜臀| 麻豆久久久久久久| 99亚洲精品| 国产精品日韩精品在线播放| 日韩国产一区二区三区| 免费日韩av| 国产精品13p| 亚洲精品自拍| 日韩另类视频| 日韩高清欧美激情| 99国产精品一区二区| 欧美午夜三级| 好看不卡的中文字幕| 国产福利一区二区三区在线播放| 久久人人99| 国产精品啊v在线| 伊人久久大香线蕉av不卡| 国产免费av国片精品草莓男男| 日韩一区亚洲二区| 日本精品另类| 欧美日韩日本国产亚洲在线| 嫩呦国产一区二区三区av| 亚洲欧美网站| 成人av三级| 国产欧美精品| 午夜在线视频一区二区区别| av日韩中文| 国产欧美另类| 久久亚洲风情| 性感美女一区二区在线观看| 91成人精品在线| 狠狠色狠狠色综合日日tαg| 国产精品白丝久久av网站| 蜜桃久久久久久| 日韩成人精品一区| 欧美日韩一区自拍| 影音先锋久久精品| 不卡一区2区| 日韩啪啪电影网| 国产精品jk白丝蜜臀av小说| 日本不卡的三区四区五区| 中文日韩在线| 国产一区亚洲| 精品成人免费一区二区在线播放| 欧美精品91| 国产欧美一区| 亚洲+小说+欧美+激情+另类| 图片区亚洲欧美小说区| 精品日韩视频| 国产一区二区三区亚洲综合| 18国产精品| 日韩视频一二区| 蜜臀久久久久久久| 国产亚洲毛片| 在线亚洲国产精品网站| 成人久久一区| 成人片免费看| 黄色aa久久| 国产中文在线播放| 国产不卡人人| 91一区二区| 中文字幕在线视频久| 欧美激情另类|