青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

隨筆 - 7  文章 - 57  trackbacks - 0
<2011年3月>
272812345
6789101112
13141516171819
20212223242526
272829303112
3456789

常用鏈接

留言簿(3)

隨筆分類

隨筆檔案

文章分類

文章檔案

搜索

  •  

最新評論

閱讀排行榜

評論排行榜

 

Q1:為什么程序的數據需要放在堆、棧兩個不同(甚至更多)的地方?

 

對于堆和棧中的數據內容來說:

棧:編譯器需知道數據內容的生存周期、但是可以快速管理和分配棧內存;

堆:編譯器無需知道數據內容的生存周期,保證靈活性、但是分配和回收內存不如把數據放在棧中來得快;

 

Q2:對象在其生命周期結束后經歷什么步驟而后被釋放?銷毀機制具體是怎樣的?底層通過什么實現?

 

 

當程序執行到一個塊or作用域(scope)的結尾,會自動清理其維護的棧中的內存數據。

于是,如果保存在棧中的唯一reference掛掉了,就意味著再沒有辦法可以操作其原先引用的對象了。

但是保存在堆中的對象在這時候還沒有被清理掉。

 

 

 

對于在堆中,沒有被引用的對象。垃圾回收器會直接把他們占據的內存空間釋放掉。

真的如書中所說,這種機制滴水不漏嗎?會不會有陷阱?

會不會有一些不經意的操作導致引用計數永遠不為零,然而用戶卻懵然不知呢?

內存泄漏真的可以在真正意義上得到避免嗎?

 

Q3:垃圾回收機制究竟能干什么,不能干什么?究竟本質是什么?

 

 

垃圾回收機制原來只會對new出來的堆內存起作用!!!

萬一不是new出來的,那還是得人工回收……

1、You might not get garbage collected!

哎……這樣的垃圾回收機制啊……

還真是懶啊……

 

總之就是,垃圾回收機制只會回收對象在堆中的內存,但究竟這個對象的操作曾經干了什么,有沒有“歷史遺留問題”,java是一概不管的……

 

 

這個垃圾回收機制還是回到回憶中去吧……(我沒吐槽最終幻想,真的沒有!)

 

 

ClassName obj//局部對象,放在棧中(C++可以這樣,java不行)

C++的好處:作用域結束,局部對象的destructor自動被調用,釋放棧中內存;

 

New出來的對象:

//C++的壞處:不執行delete的話,對象占用的內存會一直賴在堆中。就讓內存漏一會兒吧。

//java的好處:不用顯式執行,只要作用域結束,reference被清除,垃圾回收器就會自動回收堆中的內存;

而且,java兄還不讓你在棧中創建局部對象呢……

 

Q3/1那究竟new操作發生的時候,java語言為用戶干了什么?new的操作也會對引用計數產生作用——例如初始化和創建嗎?垃圾回收器如何工作呢?

 

 

 

相對于堆而言,在棧中釋放和分配內存還是效率較高。這可能也是一些程序的數據放在棧中,一些放在堆中的原因之一吧?

 

 

引用計數類似是一個對象中的成員;有東西引用對象,就增加1,當有引用在棧中被釋放或者設為NULL,就減少1;發現引用計數為0,就證明這個對象已經沒人要了……

缺點:

垃圾回收器要掃描整個對象列表,查找引用計數為0的對象;

如果有兩個對象碰巧相互引用了彼此,那這兩個對象的引用計數就用不為零,即使沒人要也不會被清除掉;

最悲催的是:

JVM都不是通過這種機制實現垃圾回收滴……

 

 

JVM是這么干的……

逆向思維,不找死的,找活的!從一個引用出發,遍歷其對象-樹(自己作的)。透過每一個在棧中或者在靜態區中保存的引用,以之為根節點,遍歷由他出發可以到達的對象節點。

好處:

不用遍歷所有堆中的對象。

解決兩個對象互相引用而導致引用計數恒不為0的問題;

 

 

經過上述處理,沒被找到的對象會被清理掉,但是會留下內存碎片,浪費空間。所以……

妙!

把程序停止下來,把活動的對象copy到新的堆內存,連續存放,這樣就騰出了那些原先成為碎片的空間。

 

然而,一直copycopy去需要有額外的堆內存來保存copy的數據,實際上copy發生的時候需要雙倍于被copy內容的堆內存同時可用。

其次,copy也需要時空開銷……

于是……

JVM就把sweep-and-markstop-and-copy結合起來(thinking in java有詳述)

大對象占用一個block,每個block有一個generation count作為其可用與否的標記。

一些小對象放在一個block里;

根據引用來遍歷其對象-樹的操作開始執行:

一般來說,大對象是不會被copy的;

小對象會被復制和重新管理,釋放內存碎片;

JVM在碎片多的時候進行stop-and-copy來整理碎片,騰出空間;在堆內存足夠和碎片不多的情況下,則只執行sweep-and-mark

 

在這樣的垃圾回收機制下,只要是new出來的東西,真的都能回收了。某程度上還真是滴水不漏啊……

 

顯然是抄IBM大型機的外存管理嘛!數據集放在block中,被刪除的數據集的block標記為不可用,新建的數據集放在后面的block中。當存儲空間不夠了,整理那些已經存在又可用的數據集,存放在一片連續空間中,把碎片重新整理為可用內存,真是……

抄吧抄吧,不是罪……

 

 

posted on 2011-03-04 20:49 ArthasLee 閱讀(870) 評論(1)  編輯 收藏 引用 所屬分類: 筆記和疑問

FeedBack:
# re: java學習筆記2——JVM和垃圾回收器 2011-03-21 00:28 陳梓瀚(vczh)
garbage collection is only about memory的意思是說“GC只管內存,不管句柄等資源”……  回復  更多評論
  

只有注冊用戶登錄后才能發表評論。
網站導航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
      <noscript id="pjuwb"></noscript>
            <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
              <dd id="pjuwb"></dd>
              <abbr id="pjuwb"></abbr>
              午夜久久福利| 亚洲欧美国产精品专区久久| 亚洲精品乱码久久久久久按摩观| 欧美国产日本韩| 亚洲视频综合在线| 亚洲欧美久久久| 国产一区视频在线观看免费| 欧美3dxxxxhd| 欧美人与性禽动交情品| 篠田优中文在线播放第一区| 久久成人18免费网站| 亚洲国内欧美| 99精品国产热久久91蜜凸| 国产精品亚洲а∨天堂免在线| 久久精品99国产精品酒店日本| 久久综合久色欧美综合狠狠| 一本大道av伊人久久综合| 亚洲免费视频一区二区| 亚洲大胆视频| 日韩亚洲欧美精品| 国产一区二区日韩| 亚洲激情午夜| 国产欧美精品一区aⅴ影院| 欧美福利电影网| 欧美午夜电影在线| 快射av在线播放一区| 欧美日本国产| 欧美资源在线观看| 欧美成人一区在线| 欧美在线不卡| 欧美大片91| 久久福利一区| 欧美成人一区二免费视频软件| 性18欧美另类| 欧美成年人视频| 久久国产视频网站| 欧美理论在线播放| 久久久蜜桃一区二区人| 欧美精品在线免费观看| 久久狠狠亚洲综合| 欧美日韩国产一区二区三区| 久久综合久久综合这里只有精品| 欧美日韩成人在线视频| 久久在线91| 国产精品theporn| 欧美激情乱人伦| 国产日韩在线一区| 亚洲乱码国产乱码精品精可以看 | 亚洲第一在线综合在线| 国产精品一区二区你懂得| 亚洲丶国产丶欧美一区二区三区| 国产精品自拍网站| 亚洲精品国产欧美| 亚洲成色999久久网站| 亚洲自拍三区| 一区二区精品国产| 快射av在线播放一区| 久久成人久久爱| 欧美日韩在线不卡一区| 亚洲国产成人在线播放| 国产一区清纯| 亚洲在线黄色| 亚洲私人影院| 欧美精品一区二区三区视频| 免费日韩精品中文字幕视频在线| 国产精品入口夜色视频大尺度| 亚洲欧洲另类| 亚洲国产精品小视频| 欧美一区二区成人| 午夜国产欧美理论在线播放| 欧美精品www在线观看| 嫩草成人www欧美| 国产香蕉久久精品综合网| 在线综合欧美| 亚洲视频免费在线观看| 欧美激情2020午夜免费观看| 欧美aaa级| 精久久久久久久久久久| 午夜伦理片一区| 亚洲欧美一区二区三区极速播放 | 国产精品99久久久久久白浆小说| 免费亚洲一区| 农村妇女精品| 红桃视频成人| 久久岛国电影| 久久久久九九九九| 国产亚洲高清视频| 亚洲在线观看视频网站| 午夜精品一区二区三区四区| 欧美视频导航| 一区二区免费在线视频| 亚洲天堂黄色| 欧美午夜理伦三级在线观看| 日韩午夜电影av| 一区二区日韩精品| 欧美日韩在线另类| 一本色道婷婷久久欧美| 国产精品99久久不卡二区| 欧美日韩免费一区| 日韩一级在线观看| 国产精品99久久久久久有的能看 | 亚洲日本在线观看| 一区二区日韩| 欧美亚韩一区| 亚洲午夜精品视频| 欧美在线精品免播放器视频| 国产欧美va欧美不卡在线| 欧美一区二区黄色| 久久香蕉国产线看观看av| 在线播放国产一区中文字幕剧情欧美| 久久人91精品久久久久久不卡| 美女脱光内衣内裤视频久久影院 | 亚洲自拍三区| 久久精品国产91精品亚洲| 韩日精品在线| 另类成人小视频在线| 亚洲国产成人tv| 一区二区三区四区蜜桃| 欧美性猛交一区二区三区精品| 亚洲性视频网站| 久久国产一区二区| 永久域名在线精品| 欧美 日韩 国产在线| 999亚洲国产精| 午夜亚洲伦理| 激情av一区二区| 欧美福利视频在线| 在线视频你懂得一区| 欧美亚洲专区| 精品成人a区在线观看| 欧美大片18| 亚洲视频免费看| 久久久久国色av免费看影院| 亚洲国产一区二区a毛片| 欧美精品久久久久久| 这里只有精品丝袜| 久久福利资源站| 亚洲黄色小视频| 欧美日韩一区二区三区视频| 亚洲欧美激情精品一区二区| 免费不卡在线观看| 一区二区三区日韩在线观看| 欧美日韩国产综合视频在线观看| 亚洲一区二区不卡免费| 蜜桃伊人久久| 一本一本大道香蕉久在线精品| 国产伦一区二区三区色一情| 麻豆成人综合网| 一区二区欧美视频| 久久在线91| 在线一区二区三区四区五区| 国产人久久人人人人爽| 暖暖成人免费视频| 亚洲视频二区| 免费看亚洲片| 亚洲在线网站| 在线精品国精品国产尤物884a| 欧美日韩激情小视频| 欧美在线观看一区| 亚洲精品日本| 久久久伊人欧美| 一区二区三区日韩欧美| 黄色日韩在线| 欧美色一级片| 久久亚洲国产精品一区二区| 亚洲少妇最新在线视频| 欧美成人精品一区二区| 亚洲男人第一网站| 亚洲国产裸拍裸体视频在线观看乱了中文 | 亚洲乱码国产乱码精品精天堂| 国产精品一区二区三区乱码| 免费久久99精品国产自在现线| 亚洲午夜久久久| 亚洲国产日韩欧美在线图片| 欧美综合77777色婷婷| 日韩午夜高潮| 在线观看福利一区| 国产精品日韩高清| 欧美激情视频给我| 久久久久成人网| 亚洲午夜精品久久久久久浪潮 | 日韩网站在线观看| 欧美大片va欧美在线播放| 香蕉久久夜色| 在线视频中文亚洲| 亚洲成人在线视频网站| 国产乱子伦一区二区三区国色天香| 欧美成人一区二区在线| 久久精品日产第一区二区| 亚洲视频一二| 亚洲人成啪啪网站| 欧美大片在线观看一区| 久久精品国产69国产精品亚洲| 亚洲视频一二三| 亚洲日本中文字幕区| 一区二区视频免费完整版观看| 国产精品普通话对白| 欧美性猛交99久久久久99按摩 | 亚洲国产精品成人综合色在线婷婷| 国产女人水真多18毛片18精品视频|