用過(guò)C語(yǔ)言的開(kāi)發(fā)人員都知道,內(nèi)存的管理一直都是個(gè)頭疼事,得自己管理對(duì)象的生命周期,不當(dāng)?shù)膬?nèi)存釋放或者是使用可能會(huì)引起程序的異常,而java有GC這一個(gè)概念,能夠自動(dòng)幫你釋放內(nèi)存,我們來(lái)看一下它是如何管理內(nèi)存的
GC的意思就是Garbage Collections,意思就是垃圾回收的意思,java會(huì)判斷一個(gè)對(duì)象是否到了他的生命盡頭(不用了)來(lái)對(duì)他進(jìn)行一個(gè)垃圾回收。
首先要回收垃圾肯定得先判斷哪個(gè)是垃圾對(duì)象,有兩種方法
1.引用計(jì)數(shù)法,這種方法每個(gè)對(duì)象在生成的時(shí)候都有一個(gè)計(jì)數(shù),只要有對(duì)象引用他,該數(shù)就加一,有對(duì)象和他斷了聯(lián)系就減一,知道該對(duì)象的計(jì)數(shù)到0,這個(gè)時(shí)候就被當(dāng)成垃圾對(duì)象,被回收掉,但是該方法有缺點(diǎn),就是不能解決循環(huán)引用的問(wèn)題,例如 a引用b,b引用c , c引用a,此時(shí)三個(gè)對(duì)象的計(jì)數(shù)均不等于0,垃圾回收器就不能回收掉他們
2.可達(dá)法也叫跟搜索法, 引用了一個(gè)根的概念,任何對(duì)象的引用能到達(dá)跟的都不算是垃圾對(duì)象。當(dāng)然,也不能一下把它錘死,但是如果是兩次都是他的話(huà),達(dá)不了根的都是垃圾對(duì)象
其次就是垃圾回收的算法,共有下面幾種
1.標(biāo)記清除法 , 首先把垃圾對(duì)象標(biāo)記,標(biāo)記完垃圾對(duì)象后,就清除
其原理就是在一塊內(nèi)存區(qū)域中標(biāo)記多個(gè)垃圾獨(dú)對(duì)象,當(dāng)然對(duì)個(gè)垃圾對(duì)象的位置也可能是不同的, 這就會(huì)出現(xiàn)一個(gè)缺點(diǎn), 會(huì)出現(xiàn)內(nèi)存碎片,當(dāng)要分配一個(gè)連續(xù)的空間時(shí)就不能使用該內(nèi)存區(qū)域了,而且標(biāo)記過(guò)程和清除過(guò)程的效率都不算太高,所以說(shuō)這只是一個(gè)最基礎(chǔ)的算法.
2. 標(biāo)記壓縮算法, 此算法可以說(shuō)是解決了標(biāo)記清除算法所遺留的問(wèn)題,也就會(huì)內(nèi)存碎片,該算法會(huì)先標(biāo)記垃圾對(duì)象, 然后把垃圾對(duì)象放到內(nèi)存區(qū)域的一邊, 不是垃圾對(duì)象的放到內(nèi)存區(qū)域的另一邊, 然后清除垃圾對(duì)象, 該算法的優(yōu)點(diǎn)就是不會(huì)出現(xiàn)內(nèi)存碎片,但是會(huì)改變?cè)嫉奈恢?
3. 復(fù)制算法, 該算法是把內(nèi)存區(qū)域分為兩塊大小相同的區(qū)域, 當(dāng)一塊區(qū)域的內(nèi)存滿(mǎn)了的時(shí)候, 會(huì)把存活對(duì)象復(fù)制到另一個(gè)快內(nèi)存區(qū)域里面,然后清除原來(lái)的內(nèi)存塊兒, 把當(dāng)前使用的做為正在使用的, 這樣也沒(méi)有內(nèi)存碎片的問(wèn)題, 但缺點(diǎn)就是要把內(nèi)存分為兩塊兒, 在存活對(duì)象比較多的時(shí)候, 要進(jìn)行多次的復(fù)制, 這樣也會(huì)使效率變低
JAVA中的分代收集算法
因?yàn)楦鞣N對(duì)象的生命周期不一致, 所以我們把他們分為新生代和老年代
新生代都是一些生命周期比較短的對(duì)象,我們就是用復(fù)制算法, 老年代都是一些生命周期比較長(zhǎng)的對(duì)象我們就使用標(biāo)記清除 和 標(biāo)記壓縮 來(lái)清除垃圾對(duì)象。
咨詢(xún)熱線(xiàn)
010-85377344
135-21581588
微信客服
QQ客服
3026106565 點(diǎn)擊咨詢(xún)