python多线程同步售票系统

目录
  • 1、分析过程
  • 2、准备过程
  • 3、实现过程

解决问题场景:假如剩余1000张电影票需要售卖,同时有10家电影App来售卖这1000张电影票。主要的逻辑实现过程是什么,要求使用python技术栈进行解题?

1、分析过程

分析:主要信息点是10家App平台同时售卖1000张电影票。此时,可以使用10个python线程来作为10家App平台,同时售卖必须保证电影票数量的同步,比如A平台卖出了一张票那总共剩余的票数是999,B平台若要再卖出一张票则应该是999-1=998张票。

技术栈分析:python多线程提供了threading模块,并且threading模块提供了同步锁Lock来控制使得票数达到统一的效果。

2、准备过程

将相关的标准库导入到代码块中,不用额外安装其他的非标准库。

import threading  # 多线程相关的操作
import os  # 应用退出操作
import time  # 线程中时间阻塞的控制

初始化一些全局参数,供后面调用过程中使用。

tickets = 1000  # 初始化电影票的总数为1000张
lock_ = threading.Lock()  # 获取一个同步锁对象,用于在多线程逻辑中实现锁的控制

3、实现过程

编写一个函数sell_tickets作为售票的函数实现过程。

def sell_tickets(app_name='承担电影票售票任务App平台'):
    global tickets  # 将这些电影票作为全局变量
    global lock_  # 将获取到的锁对象作为全局变量
    # 使用一个死循环来模拟当前的售票平台一直在售票
    while True:
        lock_.acquire()  # 每个售票平台进入售票后先加锁处理
        if tickets > 0:  # 开始售票之前先判断电影票的数量是否已经售完
            tickets = tickets - 1
            print('当前售票平台:{},卖出一张电影票,剩余电影票:{}张!'.format(app_name, tickets))
            time.sleep(0.1)
        else:
            print('电影票已经全部卖完了!')
            os._exit(0)
        lock_.release()  # 处理完成售票业务后将锁释放
        time.sleep(0.2)

至此,电影票售票的业务逻辑就写完了。下面再通过多线程实现多个电影票出售平台同时售票就OK了。

app_thread_1 = threading.Thread(target=sell_tickets, args=('售票App平台01',))
app_thread_1.start()
app_thread_2 = threading.Thread(target=sell_tickets, args=('售票App平台02',))
app_thread_2.start()
app_thread_3 = threading.Thread(target=sell_tickets, args=('售票App平台03',))
app_thread_3.start()
app_thread_4 = threading.Thread(target=sell_tickets, args=('售票App平台04',))
app_thread_4.start()
app_thread_5 = threading.Thread(target=sell_tickets, args=('售票App平台05',))
app_thread_5.start()
app_thread_6 = threading.Thread(target=sell_tickets, args=('售票App平台06',))
app_thread_6.start()
app_thread_7 = threading.Thread(target=sell_tickets, args=('售票App平台07',))
app_thread_7.start()
app_thread_8 = threading.Thread(target=sell_tickets, args=('售票App平台08',))
app_thread_8.start()
app_thread_9 = threading.Thread(target=sell_tickets, args=('售票App平台09',))
app_thread_9.start()
app_thread_10 = threading.Thread(target=sell_tickets, args=('售票App平台10',))
app_thread_10.start()

到此这篇关于python多线程同步售票系统的文章就介绍到这了,更多相关python售票系统内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

(0)

相关推荐

  • 详解python多线程之间的同步(一)

    引言: 线程之间经常需要协同工作,通过某种技术,让一个线程访问某些数据时,其它线程不能访问这些数据,直到该线程完成对数据的操作.这些技术包括临界区(Critical Section),互斥量(Mutex),信号量(Semaphore),事件Event等. Event threading库中的event对象通过使用内部一个flag标记,通过flag的True或者False的变化来进行操作.      名称                                      含义 set( )

  • 基于Python实现电影售票系统

    目录 一.系统要求 二.用户信息 三.主要代码 四.效果图展示 一.系统要求 电影售票系统程序,应具备以下几点功能: 1.用户认证 系统用户分为用户.管理员两个角色,系统可根据不同用户角色权限进入不同界面,所有用户角色需要通过身份验证才能登录系统进行操作. 2.用户登录 主要实现用户登录系统可查看本人会员信息.购买影票.查看订票.影票退订.修改信息等功能. 3.管理登录 主要实现管理员登录系统可查看会员和管理信息.添加会员.注销会员.查看购票.影票出售.影票退订.查看影票余票和售票.增删管理.增

  • Python多线程同步Lock、RLock、Semaphore、Event实例

    一.多线程同步 由于CPython的python解释器在单线程模式下执行,所以导致python的多线程在很多的时候并不能很好地发挥多核cpu的资源.大部分情况都推荐使用多进程. python的多线程的同步与其他语言基本相同,主要包含: Lock & RLock :用来确保多线程多共享资源的访问. Semaphore : 用来确保一定资源多线程访问时的上限,例如资源池.  Event : 是最简单的线程间通信的方式,一个线程可以发送信号,其他的线程接收到信号后执行操作. 二.实例 1)Lock &a

  • python多线程同步之文件读写控制

    本文实例为大家分享了python多线程同步之文件读写控制的具体代码,供大家参考,具体内容如下 1.实现文件读写的文件ltz_schedule_times.py #! /usr/bin/env python #coding=utf-8 import os def ReadTimes(): res = [] if os.path.exists('schedule_times.txt'): fp = open('schedule_times.txt', 'r') else: os.system('to

  • Python多线程同步---文件读写控制方法

    1.实现文件读写的文件ltz_schedule_times.py #! /usr/bin/env python #coding=utf-8 import os def ReadTimes(): res = [] if os.path.exists('schedule_times.txt'): fp = open('schedule_times.txt', 'r') else: os.system('touch schedule_times.txt') fp = open('schedule_ti

  • Python使用面向对象方式创建线程实现12306售票系统

    目前python 提供了几种多线程实现方式 thread,threading,multithreading ,其中thread模块比较底层,而threading模块是对thread做了一些包装,可以更加方便的被使用. 面向对象技术简介 类(Class): 用来描述具有相同的属性和方法的对象的集合.它定义了该集合中每个对象所共有的属性和方法.对象是类的实例. 类变量:类变量在整个实例化的对象中是公用的.类变量定义在类中且在函数体之外.类变量通常不作为实例变量使用. 数据成员:类变量或者实例变量用于

  • python多线程同步售票系统

    目录 1.分析过程 2.准备过程 3.实现过程 解决问题场景:假如剩余1000张电影票需要售卖,同时有10家电影App来售卖这1000张电影票.主要的逻辑实现过程是什么,要求使用python技术栈进行解题? 1.分析过程 分析:主要信息点是10家App平台同时售卖1000张电影票.此时,可以使用10个python线程来作为10家App平台,同时售卖必须保证电影票数量的同步,比如A平台卖出了一张票那总共剩余的票数是999,B平台若要再卖出一张票则应该是999-1=998张票. 技术栈分析:pyth

  • python多线程同步实例教程

    前言 进程之间通信与线程同步是一个历久弥新的话题,对编程稍有了解应该都知道,但是细说又说不清.一方面除了工作中可能用的比较少,另一方面就是这些概念牵涉到的东西比较多,而且相对较深.网络编程,服务端编程,并发应用等都会涉及到.其开发和调试过程都不直观.由于同步通信机制的原理都是想通的,本文希通过望借助python实例来将抽象概念具体化. 阅读之前可以参考之前的一篇文章:python多线程与多进程及其区别,了解一下线程和进程的创建. python多线程同步 python中提供两个标准库thread和

  • Java多线程Runable售票系统实现过程解析

    一.无等待,直接出票[虽然解决了不会冲票问题,但显然不符合实际生活]: package com.thread.sale; public class Sale { public static void main(String[] args) {//悟,那么设计爬虫的时候,下载的资源唯一,使用多线程下载 SaleTickets t = new SaleTickets();//关键在这里,只创建一个对象,而后交给线程去执行这个任务,达到目的 Thread thread1 = new Thread(t)

  • python多线程之事件Event的使用详解

    前言 小伙伴a,b,c围着吃火锅,当菜上齐了,请客的主人说:开吃!,于是小伙伴一起动筷子,这种场景如何实现 Event(事件) Event(事件):事件处理的机制:全局定义了一个内置标志Flag,如果Flag值为 False,那么当程序执行 event.wait方法时就会阻塞,如果Flag值为True,那么event.wait 方法时便不再阻塞. Event其实就是一个简化版的 Condition.Event没有锁,无法使线程进入同步阻塞状态. Event() set(): 将标志设为True,

  • Python利用多线程同步锁实现多窗口订票系统(推荐)

    利用Python实现多窗口订票系统,利用 threading.Lock() 避免出现一票多卖,无票也卖的情况,并规范化输出情况. 代码: import threading import time tickets, lock = 20, threading.Lock() class TicketWindows(threading.Thread): def __init__(self, window_name): threading.Thread.__init__(self) self.window

随机推荐