新聞中心

        EEPW首頁 > 嵌入式系統 > 設計應用 > 對比Ruby和Python的垃圾回收

        對比Ruby和Python的垃圾回收

        作者: 時間:2016-09-12 來源:網絡 收藏

        當然內部也會由于各種原因使用空閑對象鏈表(它使用鏈表循環確定對象),為對象和值分配內存的方式常常不同于

        本文引用地址:http://www.104case.com/article/201609/304199.htm

        假設我們創建一個Node對象使用

        pythobvdfbfdbdfbn1

        Python不同于,當你創建對象的時候,Python會立即向操作系統申請分配內存。(Python 事實上實現了自己的內存分配系統,它在操作系統內存堆上提供了另外一層抽象,但是今天沒有事件深入探討。 )

        當我們創建第二個對象時,Python將再次向操作系統申請更多的內存:

        python2fbfdhhrt

        看起來相當簡單,當我們創建Python對象的時刻,將花費事件申請內存。

        menbfgnfgnfhss

        將沒有用的對象扔的到處都是,直到下一個過程

        Ruby開發者生活在一個臟亂的房間

        回到Ruby,由于我們分配越來越多的對象,Ruby將繼續為我們從空閑對象鏈表(free list)獲取預分配對象。因此,空閑對象鏈表將變得越來越短:

        fregergregrgge-list4

        或者更短:

        freederfreferfg-list5

        請注意,我將一個新的值賦給了n1,Ruby會遺留下舊的值。”ABC”, “JKL”和”MNO”等結點對象會依然保留在內存中。Ruby不會立即清理舊的對象盡管程序不再使用!作為一名Ruby開發者就像生活在一個臟亂的房間,衣服隨意的仍在地板上,廚房的水槽中堆滿了臟盤子。作為一個Ruby開發者,你必須在一大堆垃圾對象中去工作。

        clfgdgergerggrean

        當你的程序不在使用任何對象的時候,Python會立刻進行清理。

        Python開發者生活在一所整潔的房子

        機制在Python和Ruby中迥然不同,讓我們回到前面三個Python中Node對象的例子:

        pythfgbfgbfgbnfgon3b

        內部的,每當我們新建一個對象,Python將在對象對應的C語言結構中保存一個數字,叫做引用技術。最初,Python將它的值設為1。

        pytefwefwefwefghon4

        值為1表明每個對象有一個指針或引用指向它。假設我們創建一個新的對象,JKL:

        pythgbfgbfbfgbon5

        正如前面所說,Python將”JKL”的引用計數設置為1。同樣注意到我們改變n1指向了”JKL”,不再引用”ABC”,同時將”ABC”的引用計數減少為0。

        通過這一點,Python器將會立即執行!無論何時,只要一個對象的引用計數變為0,python將立即釋放這個對象,并且將它的內存返回給操作系統。

        pythgfbfgbfgnbfgnon6

        上圖中,Python將回收”ABC”對象的內存。記住,Ruby只是將舊的對象遺留在那里并且不去釋放它們占用的內存。

        這種垃圾回收算法被稱為”引用計數”,由喬治柯林斯發明于1960年。非常巧合的是在同一年約翰麥卡錫大叔發明了”空閑對象鏈表算法”。正如Mike Bernstein在Ruby Conference大會上所說”1960年是屬于垃圾回收器的…”。

        作為一個Python開發者,就像生活在一個整潔的房間中。你知道,你的室友有些潔癖,他會把你使用過的任何東西都清洗一遍。你把臟盤子,臟杯子一放到水槽中他就會清洗。

        現在看另外一個例子,假設我們讓n2和n1指向同樣的結點:

        pytvwefwefwefhon8

        上圖左邊可以看到,Python減少了”DEF”的引用計數并且立即回收了”DEF”對象。同時可以看到,由于n1和n2同時指了”JKL”對象,所以它的引用計數變為了2。

        標記回收算法

        最終臟亂的房間將堆慢垃圾,生活不能總是如此。Ruby程序在運行一段時間之后,空閑對象鏈表最終將被用盡。

        mark-fthrthand-sweep1

        上圖中所有的預分配對象都被用盡(方塊全部變成了灰色),鏈表上沒有對象可用(沒有剩余的白色方塊)。

        此時,Ruby使用了一種由約翰麥卡錫發明的被稱為”標記回收”的算法。首先,Ruby將停止程序的執行,Ruby使用了”停止這個世界,然后回收垃圾”的方式。然后,Ruby會掃描所有的指向對象和值的指針或引用。同樣,Ruby也會迭代虛擬機內部使用的指針。它會標記每一個指針所能到達的對象。在下圖中,我使用了”M”指出了這些標記:



        關鍵詞: Ruby Python 垃圾回收

        評論


        相關推薦

        技術專區

        關閉
        主站蜘蛛池模板: 叙永县| 顺昌县| 荣成市| 上栗县| 迁安市| 弋阳县| 马关县| 西和县| 库伦旗| 万源市| 台州市| 郁南县| 苗栗市| 乐亭县| 定襄县| 双鸭山市| 孝感市| 霍邱县| 芜湖市| 四子王旗| 屯留县| 平泉县| 阿克| 永胜县| 古丈县| 梁山县| 吉安县| 容城县| 武鸣县| 台北县| 岐山县| 宜君县| 专栏| 石阡县| 鱼台县| 津南区| 新安县| 隆林| 龙井市| 年辖:市辖区| 新龙县|