python 多线程笔记(4)-- 车站售票模拟

简介: import threading import time import random class Worker(threading.Thread): '''售票员''' def __init__(self, wait_num=5, index=0): super().

 

import threading
import time
import random

class Worker(threading.Thread):
    '''售票员'''
    def __init__(self, wait_num=5, index=0):
        super().__init__()
        self.wait_num = wait_num          # 当前排队人数
        self.setName('窗口' + str(index)) # 窗口号
 
    def run(self):
        global counter, mutex
        
        while counter and self.wait_num: # 若有余票且有人排队
            # ============================
            # 窗口问询
            # ============================
            time.sleep(random.randrange(2,10)) # 比较耗时,时间随机
            
            # ============================
            # 出票
            # ============================
            mutex.acquire()         # 锁住①
            if counter == 0:        # 如果票数为0
                mutex.release()     # 解锁③ -----> 这句很重要!!!
                print(self.getName(), ':抱歉,票已售完')
                break
                
            counter = counter - 1   # 票数减一
            print('{}:当前余票 {} 张'.format(self.getName(), counter))
            mutex.release()         # 解锁③
            
            # ============================
            # 排队人数变化
            # ============================
            self.wait_num -= 1                      # 排队人数减一
            self.wait_num += random.randrange(0,2)  # 排队人数随机增加

    
if __name__ == '__main__':
    # 剩余车票数
    counter = 20
    
    # 创建锁
    mutex = threading.Lock()
    
    # 开4个售票窗口
    workers = []
    for i in range(4):
        wait_num = random.randrange(2,10) # 窗口前排队人数随机
        workers.append(Worker(wait_num, i+1)) 
    
    # 开始售票
    for w in workers:
        w.start()
    
    # 阻塞主程/后台静默?自己选
    #for w in workers:
    #    w.join()

 

目录
相关文章
|
7月前
|
缓存 负载均衡 安全
在Python中,如何使用多线程或多进程来提高程序的性能?
【2月更文挑战第17天】【2月更文挑战第50篇】在Python中,如何使用多线程或多进程来提高程序的性能?
74 4
|
7月前
|
安全 Java 数据处理
Python网络编程基础(Socket编程)多线程/多进程服务器编程
【4月更文挑战第11天】在网络编程中,随着客户端数量的增加,服务器的处理能力成为了一个重要的考量因素。为了处理多个客户端的并发请求,我们通常需要采用多线程或多进程的方式。在本章中,我们将探讨多线程/多进程服务器编程的概念,并通过一个多线程服务器的示例来演示其实现。
|
7月前
|
安全 Python
Python中的并发编程:多线程与多进程技术探究
本文将深入探讨Python中的并发编程技术,重点介绍多线程和多进程两种并发处理方式的原理、应用场景及优缺点,并结合实例分析如何在Python中实现并发编程,以提高程序的性能和效率。
|
7月前
|
数据采集 数据库 C++
python并发编程:并发编程中是选择多线程呢?还是多进程呢?还是多协程呢?
python并发编程:并发编程中是选择多线程呢?还是多进程呢?还是多协程呢?
74 0
|
1月前
|
并行计算 数据处理 调度
Python中的并发编程:探索多线程与多进程的奥秘####
本文深入探讨了Python中并发编程的两种主要方式——多线程与多进程,通过对比分析它们的工作原理、适用场景及性能差异,揭示了在不同应用需求下如何合理选择并发模型。文章首先简述了并发编程的基本概念,随后详细阐述了Python中多线程与多进程的实现机制,包括GIL(全局解释器锁)对多线程的影响以及多进程的独立内存空间特性。最后,通过实例演示了如何在Python项目中有效利用多线程和多进程提升程序性能。 ####
|
2月前
|
Python
Python中的多线程与多进程
本文将探讨Python中多线程和多进程的基本概念、使用场景以及实现方式。通过对比分析,我们将了解何时使用多线程或多进程更为合适,并提供一些实用的代码示例来帮助读者更好地理解这两种并发编程技术。
聊聊python多线程与多进程
为什么要使用多进程与多线程呢? 因为我们如果按照流程一步步执行任务实在是太慢了,假如一个任务就是10秒,两个任务就是20秒,那100个任务呢?况且cpu这么贵,时间长了就是浪费生命啊!一个任务比喻成一个人,别个做高铁,你做绿皮火车,可想而知!接下来我们先看个例子:
|
3月前
|
数据采集 Linux 调度
Python之多线程与多进程
Python之多线程与多进程
32 0
|
5月前
|
消息中间件 安全 数据处理
Python中的并发编程:理解多线程与多进程的区别与应用
在Python编程中,理解并发编程是提高程序性能和响应速度的关键。本文将深入探讨多线程和多进程的区别、适用场景及实际应用,帮助开发者更好地利用Python进行并发编程。