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

隨筆 - 7  文章 - 57  trackbacks - 0
<2025年11月>
2627282930311
2345678
9101112131415
16171819202122
23242526272829
30123456

常用鏈接

留言簿(3)

隨筆分類

隨筆檔案

文章分類

文章檔案

搜索

  •  

最新評論

閱讀排行榜

評論排行榜

 

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

 

對于堆和棧中的數(shù)據(jù)內容來說:

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

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

 

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

 

 

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

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

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

 

 

 

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

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

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

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

 

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

 

 

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

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

1、You might not get garbage collected!

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

還真是懶啊……

 

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

 

 

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

 

 

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

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

 

New出來的對象:

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

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

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

 

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

 

 

 

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

 

 

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

缺點:

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

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

最悲催的是:

JVM都不是通過這種機制實現(xiàn)垃圾回收滴……

 

 

JVM是這么干的……

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

好處:

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

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

 

 

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

妙!

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

 

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

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

于是……

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

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

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

根據(jù)引用來遍歷其對象-樹的操作開始執(zhí)行:

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

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

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

 

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

 

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

抄吧抄吧,不是罪……

 

 

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

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

只有注冊用戶登錄后才能發(fā)表評論。
網(wǎng)站導航: 博客園   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>
              久久精品99久久香蕉国产色戒| 欧美高清视频www夜色资源网| 原创国产精品91| 欧美多人爱爱视频网站| 亚洲人成网站影音先锋播放| 亚洲欧美中文另类| 一区二区三区国产| 韩国免费一区| 亚洲永久视频| 亚洲欧美国产高清| 久久国产福利国产秒拍| 久久精品视频导航| 欧美大香线蕉线伊人久久国产精品| 亚洲一区二区三区四区在线观看| 夜夜嗨一区二区三区| 夜夜爽av福利精品导航| 亚洲欧美三级伦理| 久久亚洲综合网| 欧美日韩一区二区三区| 国产精品午夜在线| 1024精品一区二区三区| 99精品久久免费看蜜臀剧情介绍| 亚洲特黄一级片| 久久精品视频99| 亚洲第一页自拍| 一区二区三区|亚洲午夜| 亚洲欧美在线一区| 欧美国产专区| 国产毛片一区二区| 亚洲伦理在线免费看| 午夜精品久久久久久久男人的天堂 | 欧美成人福利视频| 国产精品国产三级国产专区53 | 亚洲精品色婷婷福利天堂| 亚洲免费视频中文字幕| 久热精品视频在线免费观看| 亚洲精品视频一区二区三区| 午夜性色一区二区三区免费视频| 美女视频黄免费的久久| 国产乱码精品| 国产精品99久久久久久宅男 | 先锋亚洲精品| 亚洲精品乱码久久久久| 欧美一区二区三区在| 欧美日韩精品三区| 亚洲欧洲在线播放| 欧美h视频在线| 欧美在线日韩精品| 国产精品日韩精品欧美精品| 999亚洲国产精| 免费在线观看一区二区| 亚洲自拍三区| 欧美性猛交视频| 亚洲精品在线看| 久久人人精品| 欧美一区二区在线| 国产精品永久免费观看| 亚洲深夜影院| 日韩视频免费大全中文字幕| 免费一级欧美片在线观看| 影音先锋亚洲一区| 久久天天躁狠狠躁夜夜爽蜜月| 亚洲一区制服诱惑| 欧美无砖砖区免费| 亚洲一区二区三区国产| 亚洲免费成人av电影| 欧美精品免费视频| 99国产精品久久久久老师| 亚洲欧洲日韩在线| 欧美日韩精品免费看| 亚洲在线视频免费观看| 亚洲自拍三区| 国产日韩欧美在线| 另类天堂av| 麻豆成人av| 亚洲欧洲在线看| 亚洲韩国一区二区三区| 欧美精品国产精品| 在线亚洲电影| 中文在线资源观看视频网站免费不卡| 欧美日韩成人在线观看| 亚洲一级影院| 性欧美办公室18xxxxhd| 黄色成人在线网址| 麻豆精品网站| 欧美黄色影院| 一区二区三区成人| 亚洲在线黄色| 巨胸喷奶水www久久久免费动漫| 国外成人性视频| 麻豆精品91| 欧美日韩在线播放| 香蕉久久夜色精品| 久久免费高清视频| 欧美精品入口| 欧美一级久久久| 久久免费精品视频| 亚洲美女黄网| 亚洲欧美激情视频| 一区二区三区在线不卡| 亚洲激情六月丁香| 国产情人综合久久777777| 久久阴道视频| 欧美日韩在线影院| 久久午夜精品一区二区| 蜜臀va亚洲va欧美va天堂| 午夜精品理论片| 欧美成在线观看| 久久久亚洲高清| 欧美激情视频在线播放| 久久久国产精品一区二区中文| 免费在线观看日韩欧美| 欧美中文字幕第一页| 欧美肥婆在线| 性欧美暴力猛交另类hd| 欧美www视频在线观看| 午夜日韩视频| 欧美精品一区在线播放| 久久字幕精品一区| 国产欧美综合一区二区三区| 亚洲精品日韩在线观看| 狠狠色丁香婷婷综合影院| 一区二区av在线| 亚洲欧洲日本国产| 欧美一区午夜精品| 亚洲开发第一视频在线播放| 欧美综合国产| 亚洲免费一在线| 蜜桃av噜噜一区| 欧美一区影院| 国产精品啊啊啊| 牛牛国产精品| 亚洲免费网站| 一区二区三区四区五区视频| 久久av最新网址| 亚洲一区免费视频| 蜜月aⅴ免费一区二区三区 | 亚洲第一在线综合网站| 亚洲精品中文字| 日韩午夜精品视频| 欧美在线999| 亚洲欧美日产图| 欧美精品v日韩精品v韩国精品v| 久久精品国产亚洲a| 久久久久久久高潮| 久久国产欧美日韩精品| 欧美午夜电影在线观看| 亚洲国产精品成人综合色在线婷婷| 国产九九精品视频| 欧美大秀在线观看| 亚洲国产高清在线观看视频| 欧美一区二区三区视频在线| 国产伦精品一区二区三区照片91| 亚洲成人在线免费| 国产日韩一区在线| 91久久精品久久国产性色也91| 国产一区二区日韩精品欧美精品| 91久久精品美女高潮| 日韩亚洲欧美成人| 日韩视频免费在线| 一区二区三区精密机械公司| 亚洲一区二区成人在线观看| 亚洲综合色自拍一区| 国产精品一区免费在线观看| 亚洲性av在线| 久久午夜av| 亚洲国产美女精品久久久久∴| 欧美成黄导航| 欧美在线3区| 亚洲大胆人体视频| 欧美激情一区二区三区在线视频观看| 欧美成人性网| 亚洲一区二区三区国产| 国产精品二区二区三区| 午夜伦理片一区| 久久精品人人做人人爽电影蜜月| 伊人久久亚洲热| 久久婷婷丁香| 99国产精品久久久久老师| 欧美日韩精品久久久| 一本色道久久综合亚洲精品婷婷| 亚洲视频高清| 国内精品美女在线观看| 欧美精品在线极品| 亚洲一区二区精品视频| 久久久一区二区| 亚洲精品乱码视频| 国产一区二区三区高清播放| 久久视频在线看| 麻豆精品在线视频| 亚洲视频1区| 国产精品久久影院| 久久久久久久久久久久久久一区 | 香蕉av福利精品导航| 国产日韩欧美一区在线 | 亚洲精品美女| 国产婷婷97碰碰久久人人蜜臀| 久久久久久亚洲综合影院红桃| 亚洲高清久久网| 欧美在线视频免费观看|