新聞中心

Java垃圾回收新算法

作者: 時(shí)間:2011-05-20 來源:網(wǎng)絡(luò) 收藏

從誕生以來以其在網(wǎng)絡(luò)應(yīng)用開發(fā)上獨(dú)特的魅力以及“一次開發(fā),隨處運(yùn)行”的可移植性引起了人們極大的興趣。與以往的高級(jí)語言如C/C++相比,在開發(fā)方面具有很大的優(yōu)勢,其中以對(duì)象內(nèi)存管理機(jī)制中的處理機(jī)制(GC)最為突出。

本文引用地址:http://butianyuan.cn/article/150730.htm

  1 C/C++與對(duì)象內(nèi)存管理差別

  C/C++將內(nèi)存劃分成四部分:數(shù)據(jù)區(qū)、代碼區(qū)、棧區(qū)、堆區(qū)。Java則把內(nèi)存劃分成三部分即代碼區(qū)、棧區(qū)、堆區(qū),代碼區(qū)主要用于存放程序的代碼,棧區(qū)主要用于存放局部變量、內(nèi)部變量等中間性變量,堆區(qū)主要用來存放對(duì)象。

  C/C++中的對(duì)象內(nèi)存管理是通過語句new()/delete()或malloc()/free()進(jìn)行申請(qǐng)和釋放的。用new()或malloc()申請(qǐng)內(nèi)存后,若不使用delete()或free()進(jìn)行釋放,則所申請(qǐng)的內(nèi)存一直被占用,即使不使用也不能自動(dòng)釋放,必須人為釋放,導(dǎo)致編程工作很繁瑣。

  Java中的對(duì)象內(nèi)存管理則改進(jìn)了對(duì)內(nèi)存的釋放過程,使用new()或其他方法申請(qǐng)的內(nèi)存在不使用時(shí),可以自動(dòng)進(jìn)行處理,釋放內(nèi)存,從而節(jié)省內(nèi)存,使內(nèi)存的使用更加高效、合理。

  Java中可以通過三種方法來銷毀對(duì)象實(shí)現(xiàn)內(nèi)存釋放,這三種方法被稱為Java銷毀對(duì)象的三把利劍:器;finalize方法;利用System.gc方法強(qiáng)制啟動(dòng)垃圾器。

  垃圾是一種動(dòng)態(tài)存儲(chǔ)管理技術(shù),它自動(dòng)地釋放不再被程序引用的對(duì)象,按照特定的垃圾收集實(shí)現(xiàn)資源自動(dòng)回收的功能系統(tǒng),會(huì)自動(dòng)進(jìn)行GC策略。

  2 GC概述

  Java垃圾處理主要是針對(duì)堆的管理,對(duì)堆中不使用的空間進(jìn)行回收處理。判斷一個(gè)對(duì)象的內(nèi)存空間是否無用的標(biāo)準(zhǔn)是:如果該對(duì)象不能再被程序中任何一個(gè)“活動(dòng)的部分”所引用,此時(shí)該對(duì)象的內(nèi)存空間已經(jīng)無用。所謂“活動(dòng)的部分”,是指程序中某部分參與程序的調(diào)用,正在執(zhí)行過程中,尚未執(zhí)行完畢。

  具體以下兩例予以說明:

  實(shí)例1:

  int [][]matrix=new int [2][3];

  matrix=null;

  此例中,第一句是用new語句在堆中為數(shù)組申請(qǐng)了一個(gè)空間,然后用matrix來引用此空間的對(duì)象(這里數(shù)組可以理解為對(duì)象),此時(shí)這個(gè)內(nèi)存空間就是有用的。第二句是給matrix賦空值,matrix則不再引用此數(shù)組。此時(shí),這個(gè)空間就是無用的。

  實(shí)例2:

  int [][] m1=new int[2][3];

  int [][] m2=new int[2][3];

  m1=m2;

  此例中,第一句是用new語句在堆中為數(shù)組申請(qǐng)了一個(gè)空間,用m1引用這個(gè)數(shù)組。第二句是用new語句在堆中為數(shù)組申請(qǐng)了一個(gè)空間,用m2引用這個(gè)數(shù)組。第三句是改變引用對(duì)象,把m2的引用賦給m1,則此時(shí)m1也引用m2引用的對(duì)象數(shù)組,因此,m1原來引用的數(shù)組無人引用,成為垃圾。


上一頁 1 2 3 下一頁

關(guān)鍵詞: 算法 回收 垃圾 Java

評(píng)論


相關(guān)推薦

技術(shù)專區(qū)

關(guān)閉