zoukankan      html  css  js  c++  java
  • 多进程抢票不加锁

    code
    # 文件db的内容为:{"count":1}
    # 注意一定要用双引号,不然json无法识别
    # 并发运行,效率高,但竞争写同一文件,数据写入错乱
    from multiprocessing import Process,Lock
    import time,json,random
    def search():
        dic=json.load(open('db'))
        print('剩余票数%s' %dic['count'])
     
     
    def get():
        dic=json.load(open('db'))
        time.sleep(0.1)  # 模拟读数据的网络延迟
        if dic['count'] >0:
            dic['count']-=1
            time.sleep(0.2)  # 模拟写数据的网络延迟
            json.dump(dic,open('db','w'))
            print('购票成功')
     
     
    def task():
        search()
        get()
     
     
    if __name__ == '__main__':
        for i in range(100):  # 模拟并发100个客户端抢票
            p=Process(target=task)
            p.start()
    outputs
    macname@MacdeMacBook-Pro py % python3 cccccc.py
    剩余票数1
    剩余票数1
    剩余票数1
    剩余票数1
    剩余票数1
    剩余票数1
    剩余票数1
    剩余票数1
    剩余票数1
    剩余票数1
    剩余票数1
    剩余票数1
    剩余票数1
    剩余票数1
    剩余票数1
    剩余票数1
    剩余票数1
    剩余票数1
    剩余票数1
    剩余票数1
    剩余票数1
    剩余票数1
    剩余票数1
    剩余票数1
    剩余票数1
    剩余票数1
    剩余票数1
    剩余票数1
    剩余票数1
    剩余票数1
    剩余票数1
    剩余票数1
    剩余票数1
    剩余票数1
    剩余票数1
    剩余票数1
    剩余票数1
    剩余票数1
    剩余票数1
    剩余票数1
    剩余票数1
    剩余票数1
    剩余票数1
    剩余票数1
    剩余票数1
    剩余票数1
    剩余票数1
    剩余票数1
    剩余票数1
    剩余票数1
    剩余票数1
    剩余票数1
    剩余票数1
    剩余票数1
    剩余票数1
    剩余票数1
    剩余票数1
    剩余票数1
    剩余票数1
    剩余票数1
    剩余票数1
    剩余票数1
    剩余票数1
    剩余票数1
    剩余票数1
    剩余票数1
    剩余票数1
    剩余票数1
    剩余票数1
    剩余票数1
    剩余票数1
    剩余票数1
    剩余票数1
    剩余票数1
    剩余票数1
    剩余票数1
    剩余票数1
    剩余票数1
    剩余票数1
    剩余票数1
    剩余票数1
    剩余票数1
    剩余票数1
    剩余票数1
    剩余票数1
    剩余票数1
    剩余票数1
    剩余票数1
    剩余票数1
    剩余票数1
    剩余票数1
    剩余票数1
    剩余票数1
    剩余票数1
    剩余票数1
    剩余票数1
    剩余票数1
    剩余票数1
    剩余票数1
    剩余票数1
    购票成功
    购票成功
    购票成功
    购票成功
    购票成功
    购票成功
    购票成功
    购票成功
    购票成功
    购票成功
    购票成功
    购票成功
    购票成功
    购票成功
    购票成功
    购票成功
    购票成功
    购票成功
    购票成功
    购票成功
    购票成功
    购票成功
    购票成功
    购票成功
    购票成功
    购票成功
    购票成功
    购票成功
    购票成功
    购票成功
    购票成功
    购票成功
    购票成功
    购票成功
    购票成功
    购票成功
    购票成功
    购票成功
    购票成功
    购票成功
    购票成功
    购票成功
    购票成功
    购票成功
    购票成功
    购票成功
    购票成功
    购票成功
    购票成功
    购票成功
    购票成功
    购票成功
    购票成功
    购票成功
    购票成功
    购票成功
    购票成功
    购票成功
    购票成功
    购票成功
    购票成功
    购票成功
    购票成功
    购票成功
    购票成功
    购票成功
    购票成功
    购票成功
    购票成功
    购票成功
    购票成功
    购票成功
    购票成功
    购票成功
    购票成功
    购票成功
    购票成功
    购票成功
    购票成功
    购票成功
    购票成功
    购票成功
    购票成功
    购票成功
    购票成功
    购票成功
    购票成功
    购票成功
    购票成功
    购票成功
    购票成功
    购票成功
    购票成功
    购票成功
    购票成功
    购票成功
    购票成功
    购票成功
    购票成功
    购票成功
    macname@MacdeMacBook-Pro py % cat db
    {"count": 0}                                                                 
    macname@MacdeMacBook-Pro py %
     
     
     
     
     
     
     
     
     
     
     
     

  • 相关阅读:
    .net软件反编译笔记
    Asp.Net 网站一键部署技术(上)
    C# TreeGridView 实现进程列表
    HeidiSQL Navicat
    Flask项目中邮箱模块的应用
    如何在已有的Flask项目添加数据表结构?
    把u盘刻录成系统盘
    Object '<Tbl_next_week_change_state at 0x7f2c78d849e8>' is already attached to session '4' (this is '6')
    OSError: [Errno 98] Address already in use
    Linux下设置和查看环境变量
  • 原文地址:https://www.cnblogs.com/sea-stream/p/14192854.html
Copyright © 2011-2022 走看看