搜尋
首頁後端開發Python教學用於高效能記憶體管理的強大 Python 技術

owerful Python Techniques for Efficient Memory Management

身為暢銷書作家,我邀請您在亞馬遜上探索我的書。不要忘記在 Medium 上關注我並表示您的支持。謝謝你!您的支持意味著全世界!

Python 的記憶體管理是開發高效且可擴展的應用程式的關鍵方面。作為一名開發人員,我發現掌握這些技術可以顯著提高記憶體密集型任務的效能。讓我們探索六種強大的 Python 高效能記憶體管理技術。

物件池是我常用來最小化分配和釋放開銷的策略。透過重複使用對象而不是創建新對象,我們可以減少記憶體流失並提高效能。這是物件池的簡單實作:

class ObjectPool:
    def __init__(self, create_func):
        self.create_func = create_func
        self.pool = []

    def acquire(self):
        if self.pool:
            return self.pool.pop()
        return self.create_func()

    def release(self, obj):
        self.pool.append(obj)

def create_expensive_object():
    return [0] * 1000000

pool = ObjectPool(create_expensive_object)

obj1 = pool.acquire()
# Use obj1
pool.release(obj1)

obj2 = pool.acquire()  # This will reuse the same object

此技術對於建立成本高昂或經常使用和丟棄的物件特別有用。

弱引用是Python記憶體管理庫中的另一個強大工具。它們允許我們在不增加引用計數的情況下創建物件的鏈接,這對於實現快取或避免循環引用非常有用。 weakref 模組提供了必要的功能:

import weakref

class ExpensiveObject:
    def __init__(self, value):
        self.value = value

def on_delete(ref):
    print("Object deleted")

obj = ExpensiveObject(42)
weak_ref = weakref.ref(obj, on_delete)

print(weak_ref().value)  # Output: 42
del obj
print(weak_ref())  # Output: None (and "Object deleted" is printed)

在類別中使用可以顯著減少記憶體消耗,特別是在處理許多實例時。透過定義 slots,我們告訴 Python 使用固定大小的陣列來儲存屬性,而不是動態字典:

class RegularClass:
    def __init__(self, x, y):
        self.x = x
        self.y = y

class SlottedClass:
    __slots__ = ['x', 'y']
    def __init__(self, x, y):
        self.x = x
        self.y = y

import sys

regular = RegularClass(1, 2)
slotted = SlottedClass(1, 2)

print(sys.getsizeof(regular))  # Output: 48 (on Python 3.8, 64-bit)
print(sys.getsizeof(slotted))  # Output: 24 (on Python 3.8, 64-bit)

記憶體映射檔案是一種有效處理大型資料集的強大技術。 mmap 模組允許我們將檔案直接映射到記憶體中,提供快速隨機訪問,而無需加載整個檔案:

import mmap

with open('large_file.bin', 'rb') as f:
    mm = mmap.mmap(f.fileno(), 0, access=mmap.ACCESS_READ)
    # Read 100 bytes starting at offset 1000
    data = mm[1000:1100]
    mm.close()

在處理太大而無法放入記憶體的檔案時,此方法特別有用。

識別記憶體消耗大的物件對於最佳化記憶體使用至關重要。 sys.getsizeof() 函數提供了一個起點,但它不考慮巢狀物件。為了進行更全面的記憶體分析,我經常使用第三方工具,例如 memory_profiler:

from memory_profiler import profile

@profile
def memory_hungry_function():
    list_of_lists = [[i] * 1000 for i in range(1000)]
    return sum(sum(sublist) for sublist in list_of_lists)

memory_hungry_function()

這將輸出逐行記憶體使用情況報告,幫助識別程式碼中記憶體最密集的部分。

有效管理大型集合對於記憶體密集型應用程式至關重要。在處理大型資料集時,我經常使用生成器而不是列表來增量處理資料:

def process_large_dataset(filename):
    with open(filename, 'r') as f:
        for line in f:
            yield process_line(line)

for result in process_large_dataset('large_file.txt'):
    print(result)

這種方法允許我們處理數據,而無需立即將整個數據集載入到記憶體中。

可以針對特定用例實作自訂記憶體管理方案。例如,我們可以建立一個自訂的類似清單的對象,當它變得太大時,它會自動寫入磁碟:

class ObjectPool:
    def __init__(self, create_func):
        self.create_func = create_func
        self.pool = []

    def acquire(self):
        if self.pool:
            return self.pool.pop()
        return self.create_func()

    def release(self, obj):
        self.pool.append(obj)

def create_expensive_object():
    return [0] * 1000000

pool = ObjectPool(create_expensive_object)

obj1 = pool.acquire()
# Use obj1
pool.release(obj1)

obj2 = pool.acquire()  # This will reuse the same object

此類允許我們透過自動將資料卸載到磁碟來處理大於可用記憶體的清單。

在使用科學計算中常見的 NumPy 數組時,我們可以使用記憶體映射數組來高效處理大型資料集:

import weakref

class ExpensiveObject:
    def __init__(self, value):
        self.value = value

def on_delete(ref):
    print("Object deleted")

obj = ExpensiveObject(42)
weak_ref = weakref.ref(obj, on_delete)

print(weak_ref().value)  # Output: 42
del obj
print(weak_ref())  # Output: None (and "Object deleted" is printed)

這種方法允許我們使用大於可用 RAM 的陣列,並將變更自動同步到磁碟。

對於長時間運行的伺服器應用程序,實現自訂物件快取可以顯著提高效能並減少記憶體使用:

class RegularClass:
    def __init__(self, x, y):
        self.x = x
        self.y = y

class SlottedClass:
    __slots__ = ['x', 'y']
    def __init__(self, x, y):
        self.x = x
        self.y = y

import sys

regular = RegularClass(1, 2)
slotted = SlottedClass(1, 2)

print(sys.getsizeof(regular))  # Output: 48 (on Python 3.8, 64-bit)
print(sys.getsizeof(slotted))  # Output: 24 (on Python 3.8, 64-bit)

此快取會在指定時間後自動使條目過期,從而防止長時間運行的應用程式中出現記憶體洩漏。

在處理大型文字處理任務時,使用迭代器和產生器可以顯著減少記憶體使用:

import mmap

with open('large_file.bin', 'rb') as f:
    mm = mmap.mmap(f.fileno(), 0, access=mmap.ACCESS_READ)
    # Read 100 bytes starting at offset 1000
    data = mm[1000:1100]
    mm.close()

這種方法逐行處理文件,避免了將整個文件載入到記憶體中的需要。

對於創建許多臨時物件的應用程序,使用上下文管理器可以確保正確的清理並防止記憶體洩漏:

from memory_profiler import profile

@profile
def memory_hungry_function():
    list_of_lists = [[i] * 1000 for i in range(1000)]
    return sum(sum(sublist) for sublist in list_of_lists)

memory_hungry_function()

此模式可確保資源正確釋放,即使發生異常也是如此。

在 pandas 中處理大型資料集時,我們可以使用分塊來處理可管理片段中的資料:

def process_large_dataset(filename):
    with open(filename, 'r') as f:
        for line in f:
            yield process_line(line)

for result in process_large_dataset('large_file.txt'):
    print(result)

這種方法允許我們透過分塊處理大於可用記憶體的資料集。

總之,Python 中的高效記憶體管理涉及內建語言功能、第三方工具和自訂實作的組合。透過明智地應用這些技術,我們可以創建記憶體高效且高效能的 Python 應用程序,即使在處理大型資料集或長時間運行的進程時也是如此。關鍵是了解我們應用程式的記憶體特徵,並為每個特定用例選擇適當的技術。


101 本書

101 Books是一家由人工智慧驅動的出版公司,由作家Aarav Joshi共同創立。透過利用先進的人工智慧技術,我們將出版成本保持在極低的水平——一些書籍的價格低至 4 美元——讓每個人都能獲得高品質的知識。

查看我們的書Golang Clean Code,亞馬​​遜上有售。

請繼續關注更新和令人興奮的消息。購買書籍時,搜尋 Aarav Joshi 以尋找更多我們的書籍。使用提供的連結即可享受特別折扣

我們的創作

一定要看看我們的創作:

投資者中心 | 投資者中央西班牙語 | 投資者中德意志 | 智能生活 | 時代與迴響 | 令人費解的謎團 | 印度教 | 菁英發展 | JS學校


我們在媒體上

科技無尾熊洞察 | 時代與迴響世界 | 投資人中央媒體 | 令人費解的謎團 | | 令人費解的謎團 | >科學與時代媒介 |

現代印度教

以上是用於高效能記憶體管理的強大 Python 技術的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
您如何將元素附加到Python列表中?您如何將元素附加到Python列表中?May 04, 2025 am 12:17 AM

toAppendElementStoApythonList,usetheappend()方法forsingleements,Extend()formultiplelements,andinsert()forspecificpositions.1)useeAppend()foraddingoneOnelementAttheend.2)useextendTheEnd.2)useextendexendExendEnd(

您如何創建Python列表?舉一個例子。您如何創建Python列表?舉一個例子。May 04, 2025 am 12:16 AM

TocreateaPythonlist,usesquarebrackets[]andseparateitemswithcommas.1)Listsaredynamicandcanholdmixeddatatypes.2)Useappend(),remove(),andslicingformanipulation.3)Listcomprehensionsareefficientforcreatinglists.4)Becautiouswithlistreferences;usecopy()orsl

討論有效存儲和數值數據的處理至關重要的實際用例。討論有效存儲和數值數據的處理至關重要的實際用例。May 04, 2025 am 12:11 AM

金融、科研、医疗和AI等领域中,高效存储和处理数值数据至关重要。1)在金融中,使用内存映射文件和NumPy库可显著提升数据处理速度。2)科研领域,HDF5文件优化数据存储和检索。3)医疗中,数据库优化技术如索引和分区提高数据查询性能。4)AI中,数据分片和分布式训练加速模型训练。通过选择适当的工具和技术,并权衡存储与处理速度之间的trade-off,可以显著提升系统性能和可扩展性。

您如何創建Python數組?舉一個例子。您如何創建Python數組?舉一個例子。May 04, 2025 am 12:10 AM

pythonarraysarecreatedusiseThearrayModule,notbuilt-Inlikelists.1)importThearrayModule.2)指定tefifythetypecode,例如,'i'forineizewithvalues.arreaysofferbettermemoremorefferbettermemoryfforhomogeNogeNogeNogeNogeNogeNogeNATATABUTESFELLESSFRESSIFERSTEMIFICETISTHANANLISTS。

使用Shebang系列指定Python解釋器有哪些替代方法?使用Shebang系列指定Python解釋器有哪些替代方法?May 04, 2025 am 12:07 AM

除了shebang線,還有多種方法可以指定Python解釋器:1.直接使用命令行中的python命令;2.使用批處理文件或shell腳本;3.使用構建工具如Make或CMake;4.使用任務運行器如Invoke。每個方法都有其優缺點,選擇適合項目需求的方法很重要。

列表和陣列之間的選擇如何影響涉及大型數據集的Python應用程序的整體性能?列表和陣列之間的選擇如何影響涉及大型數據集的Python應用程序的整體性能?May 03, 2025 am 12:11 AM

ForhandlinglargedatasetsinPython,useNumPyarraysforbetterperformance.1)NumPyarraysarememory-efficientandfasterfornumericaloperations.2)Avoidunnecessarytypeconversions.3)Leveragevectorizationforreducedtimecomplexity.4)Managememoryusagewithefficientdata

說明如何將內存分配給Python中的列表與數組。說明如何將內存分配給Python中的列表與數組。May 03, 2025 am 12:10 AM

Inpython,ListSusedynamicMemoryAllocationWithOver-Asalose,而alenumpyArraySallaySallocateFixedMemory.1)listssallocatemoremoremoremorythanneededinentientary上,respizeTized.2)numpyarsallaysallaysallocateAllocateAllocateAlcocateExactMemoryForements,OfferingPrediCtableSageButlessemageButlesseflextlessibility。

您如何在Python數組中指定元素的數據類型?您如何在Python數組中指定元素的數據類型?May 03, 2025 am 12:06 AM

Inpython,YouCansspecthedatatAtatatPeyFelemereModeRernSpant.1)Usenpynernrump.1)Usenpynyp.dloatp.dloatp.ploatm64,formor professisconsiscontrolatatypes。

See all articles

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

Safe Exam Browser

Safe Exam Browser

Safe Exam Browser是一個安全的瀏覽器環境,安全地進行線上考試。該軟體將任何電腦變成一個安全的工作站。它控制對任何實用工具的訪問,並防止學生使用未經授權的資源。

SecLists

SecLists

SecLists是最終安全測試人員的伙伴。它是一個包含各種類型清單的集合,這些清單在安全評估過程中經常使用,而且都在一個地方。 SecLists透過方便地提供安全測試人員可能需要的所有列表,幫助提高安全測試的效率和生產力。清單類型包括使用者名稱、密碼、URL、模糊測試有效載荷、敏感資料模式、Web shell等等。測試人員只需將此儲存庫拉到新的測試機上,他就可以存取所需的每種類型的清單。

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

SublimeText3 Linux新版

SublimeText3 Linux新版

SublimeText3 Linux最新版