



全文預(yù)覽已結(jié)束
下載本文檔
版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報或認(rèn)領(lǐng)
文檔簡介
有關(guān)Java垃圾回收機制以及內(nèi)存泄漏問題論文 java語言中一個顯著的特點就是引入了java回收機制,是c+程序員最頭疼的內(nèi)存管理的問題迎刃而解,它使得java程序員在編寫程序的時候不在考慮內(nèi)存管理。由于有個垃圾回收機制,java中的額對象不在有“作用域”的概念,只有對象的引用才有“作用域”。垃圾回收可以有效的防止內(nèi)存泄露,有效的使用空閑的內(nèi)存,下面是有關(guān)Java垃圾回收機制以及內(nèi)存泄漏問題論文,歡迎參考閱讀! 前言 在segmentfault上看到一個問題:java有完善的GC機制,那么在java中是否會出現(xiàn)內(nèi)存泄漏的問題,以及能否給出一個內(nèi)存泄漏的案例。本問題視圖給出此問題的完整答案。 垃圾回收機制簡介 在程序運行過程中,每創(chuàng)建一個對象都會被分配一定的內(nèi)存用以存儲對象數(shù)據(jù)。如果只是不停的分配內(nèi)存,那么程序遲早面臨內(nèi)存不足的問題。所以在任何語言中,都會有一個內(nèi)存回收機制來釋放過期對象的內(nèi)存,以保證內(nèi)存能夠被重復(fù)利用。 內(nèi)存回收機制按照實現(xiàn)角色的不同可以分為兩種,一種是程序員手動實現(xiàn)內(nèi)存的釋放(比如C語言)另一種則是語言內(nèi)建的內(nèi)存回收機制比如本文將要介紹的java垃圾回收機制。 Java的垃圾回收機制 在程序的運行時環(huán)境中,java虛擬機提供了一個系統(tǒng)級的垃圾回收(GC,CarbageCollection)線程,它負(fù)責(zé)回收失去引用的對象占用的內(nèi)存。理解GC的前提是理解一些和垃圾回收相關(guān)的概念,下文一一介紹這些概念。 對象在jvm堆區(qū)的狀態(tài) Java對象的實例存儲在jvm的堆區(qū),對于GC線程來說,這些對象有三種狀態(tài)。 1.可觸及狀態(tài):程序中還有變量引用,那么此對象為可觸及狀態(tài)。 2.可復(fù)活狀態(tài):當(dāng)程序中已經(jīng)沒有變量引用這個對象,那么此對象由可觸及狀態(tài)轉(zhuǎn)為可復(fù)活狀態(tài)。CG線程將在一定的時間準(zhǔn)備調(diào)用此對象的finalize方法(finalize方法繼承或重寫子Object),finalize方法內(nèi)的代碼有可能將對象轉(zhuǎn)為可觸及狀態(tài),否則對象轉(zhuǎn)化為不可觸及狀態(tài)。 3.不可觸及狀態(tài):只有當(dāng)對象處于不可觸及狀態(tài)時,GC線程才能回收此對象的內(nèi)存。 GC為了能夠正確釋放對象,必須監(jiān)控每一個對象的運行狀態(tài),包括對象的申請、引用、被引用、賦值等,GC都需要進(jìn)行監(jiān)控,所以無論一個對象處于上文中的任何狀態(tài)GC都會知道。 上文說到,GC線程會在一定的時間執(zhí)行可復(fù)活狀態(tài)對象的finalize方法,那么何時執(zhí)行呢?由于不同的JVM實現(xiàn)者可能使用不同的算法管理GC,所以在任何時候,開發(fā)者無法預(yù)料GC線程進(jìn)行各項操作(包括檢測對象狀態(tài)、釋放對象內(nèi)存、調(diào)用對象的finalize方法)的時機。雖然可以通過System.gc()和Runtime.gc()函數(shù)提醒GC線程盡快進(jìn)行垃圾回收操作,但是這也無法保證GC線程馬上就會進(jìn)行相應(yīng)的回收操作。 內(nèi)存泄露 內(nèi)存泄漏指由于錯誤的設(shè)計造成程序未能釋放已經(jīng)不再使用的內(nèi)存,造成資源浪費。GC會自動清理失去引用的對象所占用的內(nèi)存。但是,由于程序設(shè)計錯誤而導(dǎo)致某些對象始終被引用,那么將會出現(xiàn)內(nèi)存泄漏。 比如下面的例子。使用數(shù)組實現(xiàn)了一個棧,有入棧和出棧兩個操作。 import.sun.javafx.collections.ElementObservableListDecorator;ernal.plaf.metal.resources.metal_sv;importjava.beans.ExceptionListener;importjava.util.EmptyStackException;/*Createdbypengon14-9-21.*/publicclassMyStackprivateObjectelements;privateintIncrement=10;privateintsize=0;publicMyStack(intsize)elements=newObjectsize;/入棧publicvoidpush(Objecto)capacity();elementssize+=o;/出棧publicObjectpop()if(size=0)thrownewEmptyStackException();returnelements-size;/增加棧的容量privatevoidcapacity()if(elements.length!=size)return;ObjectnewArray=newObjectelements.length+Increment;System.arraycopy(elements,0,newArray,0,size);publicstaticvoidmain(Stringargs)MyStackstack=newMyStack(100);for(inti=0;i100;i+)stack.push(newInteger(i);for(inti=0;i100;i+)System.out.println(stack.pop().toString(); 這個程序是可用的,支持常用的入棧和出棧操作。但是,有一個問題沒有處理好,就是當(dāng)出棧操作的時候,并沒有釋放數(shù)組中出棧元素的引用,這導(dǎo)致程序?qū)⒁恢北3謱@個Object的引用(此object由數(shù)組引用),GC永遠(yuǎn)認(rèn)為此對象是可觸及的,也就更加談不上釋放其內(nèi)存了。這就是內(nèi)存泄漏的一個典型案例。針對此,
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 軟件調(diào)試工具創(chuàng)新-洞察闡釋
- 非線性動態(tài)系統(tǒng)的反饋機制探索-洞察闡釋
- 沙灘車俱樂部運營管理方案
- 鄂爾多斯應(yīng)用技術(shù)學(xué)院《強化傳熱》2023-2024學(xué)年第二學(xué)期期末試卷
- 西南政法大學(xué)《曲式與作品分析2》2023-2024學(xué)年第二學(xué)期期末試卷
- 票務(wù)代理平臺數(shù)據(jù)隱私保護(hù)機制-洞察闡釋
- 企業(yè)創(chuàng)新戰(zhàn)略中的項目管理創(chuàng)新-洞察闡釋
- 早期診斷技術(shù)在輸血感染中的應(yīng)用-洞察闡釋
- 青年就業(yè)與心理健康結(jié)合-洞察闡釋
- 企業(yè)國際化中的風(fēng)險管理與控制-洞察闡釋
- 大學(xué)生心理健康教育導(dǎo)論
- 浙江理工大學(xué)《統(tǒng)計學(xué)與R語言》2023-2024學(xué)年第二學(xué)期期末試卷
- 2025年廣西壯族自治區(qū)林業(yè)局直屬事業(yè)單位筆試題庫帶答案分析
- 公司社保掛靠管理制度
- 市政道路施工的安全措施與管理
- 2024年江蘇理工學(xué)院招聘專職輔導(dǎo)員真題
- 小學(xué)英語教育教學(xué)論文大全
- 2025年全省民政行業(yè)職業(yè)技能大賽(孤殘兒童護(hù)理員)備考試題庫(含答案)
- 食堂保溫箱管理制度
- 風(fēng)電場預(yù)警管理制度
- 南京鼓樓醫(yī)院合作協(xié)議書
評論
0/150
提交評論