1.模拟银行服务完成程序代码
目前,在以银行营业大厅为代表的窗口行业中大量使用排队(叫号)系统,该系统完全模拟了人群排队全过程,通过取票进队、排队等待、叫号服务等功能,代替了人们站队的辛苦。
排队叫号软件的具体操作流程为:
顾客取服务序号
当顾客抵达服务大厅时,前往放置在入口处旁的取号机,并按一下其上的相应服务按钮,取号机会自动打印出一张服务单。单上显示服务号及该服务号前面正在等待服务的人数。
服务员工呼叫顾客
服务员工只需按一下其柜台上呼叫器的相应按钮,则顾客的服务号就会按顺序的显示在显示屏上,并发出“叮咚”和相关语音信息,提示顾客前往该窗口办事。当一位顾客办事完毕后,柜台服务员工只需按呼叫器相应键,即可自动呼叫下一位顾客。
编写程序模拟上面的工作过程,主要要求如下:
程序运行后,当看到“请点击触摸屏获取号码:”的提示时,只要按回车键,即可显示“您的号码是:XXX,您前面有 YYY 位”的提示,其中XXX 是所获得的服务号码,YYY 是在 XXX 之前来到的正在等待服务的人数。
用多线程技术模拟服务窗口(可模拟多个),具有服务员呼叫顾客的行为,假设每个顾客服务的时间是10000ms,时间到后,显示“请 XXX 号到 ZZZ 号窗口!”的提示。其中 ZZZ 是即将为客户服务的窗口号。
代码:
以下为 python 实现:
from Task04_Queue.linkedQueue import LinkedQueue import threading import time class LinkBankQueue(LinkedQueue): def __init__(self): LinkedQueue.__init__(self) self.callNumber = 0 def getCallNumber(self): if self.is_empty() and self.callNumber == 0: self.callNumber = 1 else: self.callNumber += 1 return self.callNumber def getLength(self): if self.is_empty(): return 0 else: cur = self._head len = 1 while cur != self._tail: cur = cur.next len += 1 return len # 服务器 class ServiceWindow(threading.Thread): def __init__(self): threading.Thread.__init__(self) self.bankQueue = None self.lock = threading.Lock() def service(self): self.lock.acquire() while True: time.sleep(20) try: if not self.bankQueue.is_empty(): print('请 %d 号到 %s 号窗口' % (self.bankQueue._head.data, threading.current_thread().name)) self.bankQueue.dequeue() # time.sleep(10) else: print('队列为空哦') finally: self.lock.release() # 客户端 if __name__ == '__main__': bankQueue = LinkBankQueue() windowcount = 2 serviceWindows = [None] * windowcount threadList = [None] * windowcount for i in range(windowcount): serviceWindows[i] = ServiceWindow() serviceWindows[i].bankQueue = bankQueue threadList[i] = threading.Thread(name=(i + 1), target=serviceWindows[i].service, args=()) threadList[i].start() while True: input('请点击触摸屏获取号码:') callNumber = bankQueue.getCallNumber() if bankQueue != None: print('您的号码是:%d,您前面有 %d 位' % (callNumber, bankQueue.getLength())) bankQueue.enqueue(callNumber) else: print('您的号码是:%d,您前面有 0 位' % (callNumber))
结果截图:
总结
以上所述是小编给大家介绍的python多线程实现代码(模拟银行服务操作流程),希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对小牛知识库网站的支持!
如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!
本文向大家介绍pandas apply多线程实现代码,包括了pandas apply多线程实现代码的使用技巧和注意事项,需要的朋友参考一下 一、多线程化选择 并行化一个代码有两大选择:multithread 和 multiprocess。 Multithread,多线程,同一个进程(process)可以开启多个线程执行计算。每个线程代表了一个 CPU 核心,这么多线程可以访问同
本文向大家介绍pycharm 实现本地写代码,服务器运行的操作,包括了pycharm 实现本地写代码,服务器运行的操作的使用技巧和注意事项,需要的朋友参考一下 无图形界面的代码编写 python代码作为脚本语言,其实最好直接使用vim在字符界面里面直接编写,这才是正道,但是作初学者,其实直接在服务器上写代码是很不习惯的,所以我这边希望能写一篇帮助师弟师妹使用本地的ide编写代码,然后服务器的解释器
本文向大家介绍python 多线程实现检测服务器在线情况,包括了python 多线程实现检测服务器在线情况的使用技巧和注意事项,需要的朋友参考一下 需要ping一个网段所有机器的在线情况,shell脚步运行时间太长,用python写个多线程ping吧,代码如下: 效果如下: 平一个网段只要2.7s左右,够快!!! 再给大家分享一个检测外网服务器的方法及代码 经常使用python检测服务器是否能pi
本文向大家介绍python threading模块操作多线程介绍,包括了python threading模块操作多线程介绍的使用技巧和注意事项,需要的朋友参考一下 python是支持多线程的,并且是native的线程。主要是通过thread和threading这两个模块来实现的。thread是比较底层的模块,threading是对thread做了一些包装的,可以更加方便的被使用。这里需要提一下的是
本文向大家介绍C#实现多线程的Web代理服务器实例,包括了C#实现多线程的Web代理服务器实例的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了C#实现多线程的Web代理服务器。分享给大家供大家参考。具体如下: 希望本文所述对大家的C#程序设计有所帮助。
本文向大家介绍Python实现多线程下载文件的代码实例,包括了Python实现多线程下载文件的代码实例的使用技巧和注意事项,需要的朋友参考一下 实现简单的多线程下载,需要关注如下几点: 1.文件的大小:可以从reponse header中提取,如“Content-Length:911”表示大小是911字节 2.任务拆分:指定各个线程下载的文件的哪一块,可以通过request header中添加“R