Python垃圾回收機制

来源:http://www.cnblogs.com/Vito2008/archive/2016/02/17/5195355.html
-Advertisement-
Play Games

引用計數 Python預設的垃圾收集機制是“引用計數”,每個對象維護了一個ob_ref欄位。它的優點是機制簡單,當新的引用指向該對象時,引用計數加1,當一個對象的引用被銷毀時減1,一旦對象的引用計數為0,該對象立即被回收,所占用的記憶體將被釋放。它的缺點是需要額外的空間維護引用計數,不過最主要的問題是


  • 引用計數

    Python預設的垃圾收集機制是“引用計數”,每個對象維護了一個ob_ref欄位。它的優點是機制簡單,當新的引用指向該對象時,引用計數加1,當一個對象的引用被銷毀時減1,一旦對象的引用計數為0,該對象立即被回收,所占用的記憶體將被釋放。它的缺點是需要額外的空間維護引用計數,不過最主要的問題是它不能解決“迴圈引用”。

    什麼是迴圈引用?A和B相互引用而再沒有外部引用A與B中的任何一個,它們的引用計數雖然都為1,但顯然應該被回收,例子:

      a = { } # a 的引用為 1
      b = { } # b 的引用為 1
      a['b'] = b # b 的引用增 1,b的引用為2
      b['a'] = a # a 的引用增 1,a的引用為 2
      del a # a 的引用減 1,a的引用為 1
      del b # b 的引用減 1, b的引用為 1
    

    在這個例子中,del語句減少了 a 和 b 的引用計數並刪除了用於引用的變數名,可是由於兩個對象各包含一個對方對象的引用,雖然最後兩個對象都無法通過名字訪問了,但引用計數並沒有減少到零。因此這個對象不會被銷毀,它會一直駐留在記憶體中,這就造成了記憶體泄漏。為瞭解決迴圈引用問題,Python引入了標記-清除和分代回收兩種GC機制。

  • 標記清除

    標記——清除(Mark——Sweep)是一種基於追蹤(Tracing)回收技術實現的垃圾回收演算法,對象之間通過引用(指針)連在一起,構成一個有向圖,對象構成這個有向圖的節點,而引用關係構成這個有向圖的邊。從根對象(root object)出發,沿著有向邊遍歷對象,可達的對象標記為有用的對象,不可達的對象就是要被清除的對象。所謂根對象就是一些全局引用對象和函數棧中的引用,這些引用所引用的對象是不可被刪除的。

    標記清除演算法作為Python的輔助垃圾收集技術主要處理的是一些容器對象,比如list、dict、tuple,instance等,因為對於字元串、數值對象是不可能造成迴圈引用問題。Python使用一個雙向鏈表將這些容器對象組織起來。

  • 分代回收

    分代回收是一種以空間換時間的操作方式,Python將記憶體根據對象的存活時間劃分為不同的集合,每個集合稱為一個代,Python將記憶體分為了3“代”,分別為年輕代(第0代)、中年代(第1代)、老年代(第2代),他們對應的是3個鏈表,它們的垃圾收集頻率與對象的存活時間的增大而減小。新創建的對象都會分配在年輕代,年輕代鏈表的總數達到上限時,Python垃圾收集機制就會被觸發,把那些可以被回收的對象回收掉,而那些不會回收的對象就會被移到中年代去,依此類推,老年代中的對象是存活時間最久的對象,甚至是存活於整個系統的生命周期內。同時,分代回收是建立在標記清除技術基礎之上。

    分代回收同樣作為Python的輔助垃圾收集技術處理那些容器對象

FROM: http://foofish.net/blog/94/python-gc


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 怪盜基德的滑翔翼 總時間限制: 1000ms 記憶體限制: 65536kB描述 怪盜基德是一個充滿傳奇色彩的怪盜,專門以珠寶為目標的超級盜竊犯。而他最為突出的地方,就是他每次都能逃脫中村警部的重重圍堵,而這也很大程度上是多虧了他隨身攜帶的便於操作的滑翔翼。 有一天,怪盜基德像往常一樣偷走了一顆珍貴的鑽
  • 1、基本概念 一次http請求 輸入(Request):header信息、get信息、post數據等 輸出(Response):symfony經過處理返回的信息,包括頁面、json字元串、URL跳轉等 2、Request $this->getRequest() httpie工具 HTTPie (讀a
  • 環境 Badboy version 2.1.1 JDK: 1.7.0_67 Apache JMeter-2.11 ---------------------------------------------------------------------------------------------
  • 給出一個整數n(n<=2000)(代碼可適用n<=10^31)和k個變換規則(k<=15)。 規則:1、1個數字可以變換成另1個數字; 2、規則中右邊的數字不能為零。 BFS 1 #include <stdio.h> 2 #include <string.h> 3 #define maxn 1000
  • 思路: 用迴圈提取最裡面的括弧,再進行運算 運算時利用正則表達式尋找相應的運算符 先進行乘除,再進行加減 (參考武sir和金角大王的代碼) 流程圖: 代碼: 1 #!/usr/bin/env python 2 # -*- coding:utf-8 -*- 3 import re 4 def chen
  • C語言數據結構之棧:中綴表達式的計算
  • 安裝環境: CentOS release 6.3 (Final) about 64bit cpu 1, http://www.oracle.com下載最新版的javase的jdk環境 比如我下載的是:jdk-8u73-linux-x64.tar.gz 2,上傳到 /usr/java下 3,tar -
  • public static void main(String[] args) { Integer i1 = new Integer(1); Integer i2 = new Integer(1); // i1,i2分別位於堆中不同的記憶體空間 System.out.println("i1 == i2:
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...