Python多进程-变量共享

一、问题描述

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

二、代码举例

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)

  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值