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