久久久久久国产精品免费免,久久成人免费观看全部免费,久久久久久久久久免免费精品

當前位置:首頁 > 網站開發 > 垃圾回收GC
網站開發 APP開發 小程序開發 SEO優化 公司新聞

垃圾回收GC

2018-06-20 09:30:20
1002

  用過C語言的開發人員都知道,內存的管理一直都是個頭疼事,得自己管理對象的生命周期,不當的內存釋放或者是使用可能會引起程序的異常,而java有GC這一個概念,能夠自動幫你釋放內存,我們來看一下它是如何管理內存的

  GC的意思就是Garbage Collections,意思就是垃圾回收的意思,java會判斷一個對象是否到了他的生命盡頭(不用了)來對他進行一個垃圾回收。

  首先要回收垃圾肯定得先判斷哪個是垃圾對象,有兩種方法

  1.引用計數法,這種方法每個對象在生成的時候都有一個計數,只要有對象引用他,該數就加一,有對象和他斷了聯系就減一,知道該對象的計數到0,這個時候就被當成垃圾對象,被回收掉,但是該方法有缺點,就是不能解決循環引用的問題,例如 a引用b,b引用c , c引用a,此時三個對象的計數均不等于0,垃圾回收器就不能回收掉他們

  2.可達法也叫跟搜索法, 引用了一個根的概念,任何對象的引用能到達跟的都不算是垃圾對象。當然,也不能一下把它錘死,但是如果是兩次都是他的話,達不了根的都是垃圾對象

  其次就是垃圾回收的算法,共有下面幾種

  1.標記清除法 , 首先把垃圾對象標記,標記完垃圾對象后,就清除

  其原理就是在一塊內存區域中標記多個垃圾獨對象,當然對個垃圾對象的位置也可能是不同的, 這就會出現一個缺點, 會出現內存碎片,當要分配一個連續的空間時就不能使用該內存區域了,而且標記過程和清除過程的效率都不算太高,所以說這只是一個最基礎的算法.

  2. 標記壓縮算法, 此算法可以說是解決了標記清除算法所遺留的問題,也就會內存碎片,該算法會先標記垃圾對象, 然后把垃圾對象放到內存區域的一邊, 不是垃圾對象的放到內存區域的另一邊, 然后清除垃圾對象, 該算法的優點就是不會出現內存碎片,但是會改變原始的位置.

  3. 復制算法, 該算法是把內存區域分為兩塊大小相同的區域, 當一塊區域的內存滿了的時候, 會把存活對象復制到另一個快內存區域里面,然后清除原來的內存塊兒, 把當前使用的做為正在使用的, 這樣也沒有內存碎片的問題, 但缺點就是要把內存分為兩塊兒, 在存活對象比較多的時候, 要進行多次的復制, 這樣也會使效率變低

  JAVA中的分代收集算法

  因為各種對象的生命周期不一致, 所以我們把他們分為新生代和老年代

  新生代都是一些生命周期比較短的對象,我們就是用復制算法, 老年代都是一些生命周期比較長的對象我們就使用標記清除 和 標記壓縮 來清除垃圾對象。

?
<rp id="cxbmw"></rp>

<sup id="cxbmw"></sup>
  • <rp id="cxbmw"><form id="cxbmw"><nav id="cxbmw"></nav></form></rp>
    <big id="cxbmw"><delect id="cxbmw"><font id="cxbmw"></font></delect></big>
    <rp id="cxbmw"></rp>
    主站蜘蛛池模板: 舞钢市| 萨迦县| 遵义市| 林甸县| 江达县| 青州市| 双峰县| 汉沽区| 凌源市| 翼城县| 萨嘎县| 独山县| 南雄市| 尚义县| 连云港市| 通许县| 砚山县| 夹江县| 沂水县| 乐安县| 南岸区| 肃北| 五峰| 仲巴县| 绥化市| 浮山县| 甘洛县| 平罗县| 竹山县| 左权县| 北宁市| 蒙城县| 和平县| 东丰县| 阳朔县| 沅陵县| 左云县| 拜泉县| 县级市| 赣州市| 郴州市|