pyinstaller 与 multiprocessing 冲突

博客指出使用PyInstaller打包前程序运行正常,打包后出现内存泄漏问题,并给出解决办法,即参考链接https://github.com/pyinstaller/pyinstaller/wiki/Recipe-Multiprocessing ,增加一行multiprocessing.freeze_support()。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

没打包之前运行没问题 , pyinstaller 打包之后 会内存泄漏

# -*- coding: utf-8 -*-
from multiprocessing import Process, Queue
import os, time, random

# 写数据进程执行的代码:
def write(q):
    print('Process to write: %s' % os.getpid())
    for value in ['A', 'B', 'C']:
        print('Put %s to queue...' % value)
        q.put(value)
        time.sleep(random.random())

# 读数据进程执行的代码:
def read(q):
    print('Process to read: %s' % os.getpid())
    while True:
        value = q.get(True)
        print('Get %s from queue.' % value)

if __name__=='__main__':
    # 父进程创建Queue,并传给各个子进程:
    q = Queue()
    pw = Process(target=write, args=(q,))
    pr = Process(target=read, args=(q,))
    # 启动子进程pw,写入:
    pw.start()
    # 启动子进程pr,读取:
    pr.start()
    # 等待pw结束:
    pw.join()

解决办法
https://github.com/pyinstaller/pyinstaller/wiki/Recipe-Multiprocessing

增加一行 multiprocessing.freeze_support() 即改成

if __name__ == '__main__':
    multiprocessing.freeze_support()
    。。。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值