Python多进程-变量共享

这篇博客探讨了在Python多进程中如何实现变量共享,通过使用`multiprocessing`模块的`Manager()`和`Lock()`来协调多个进程对共享数据的访问。示例代码展示了如何创建一个可跨进程访问的字典`share_show`,并用锁来确保在并发修改时的数据一致性。此外,还展示了Flask应用中如何结合多进程处理请求。

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

一、问题描述

使用多进程的时候变量无法共享,找到了如下方法,具体描述等以后继续优化本篇文章。

二、代码举例

import multiprocessing
import time
from multiprocessing import Process
import flask
from flask import jsonify

app = flask.Flask(__name__)


@app.route('/change_show', methods=['post', 'get'])
def change_show(share_show, share_lock, ing):
    # 假设做这件事比较耗时
    print("进入等待中……")
    time.sleep(3)
    print('change start')
    # 获取锁
    share_lock.acquire()
    share_show[5] = 20000
    share_show[10] = 20000
    share_show[0] = 88888
    # 释放锁
    share_lock.release()
    ing["ing"] = 0
    print('change end')


@app.route('/main/<int:need>', methods=['post', 'get'])
def main(need):
    # ing_cp = ing
    if not ing["ing"]:
        ing["ing"] = 1
    else:
        return jsonify({"ing": "正在使用,请稍等"})
    # 开启进程
    if need:
        p_switch = Process(target=change_show, args=(share_show, share_lock, ing,))
        p_switch.start()
        # p_switch.join()
        mess = "开启进程"
    else:
        change_show()
        mess = "正常结束"
    print(mess)
    return jsonify({"main": mess})


@app.route('/show', methods=['post', 'get'])
def show():
    print("查看 show")
    return {"show": str(share_show)}
    # return {"show": "ok"}


@app.route('/change_show', methods=['post', 'get'])
def change_show():
    share_show[2] = 555555555
    share_show[8] = 11111111111
    # show = {i: i for i in range(1000)}
    return {"change_show": 1}


@app.route('/back_ing', methods=['post', 'get'])
def back_ing():
    print("ing 复原")
    ing = {"ing": 0}
    return ing


if __name__ == '__main__':
    ing = {"ing": 0}
    share_show = multiprocessing.Manager().dict()
    share_show.update({i: i for i in range(1000)})
    share_lock = multiprocessing.Manager().Lock()
    app.run(host="0.0.0.0", port=5000, debug=True, threaded=True)

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值