Python多线程经典问题之乘客做公交车算法实例


Posted in Python onMarch 22, 2017

本文实例讲述了Python多线程经典问题之乘客做公交车算法。分享给大家供大家参考,具体如下:

问题描述:

乘客乘坐公交车问题,司机,乘客,售票员协同工作,通过多线程模拟三者的工作。
司机:开车,停车
售票员:打开车门,关闭车门
乘客:上车,下车

用Python的Event做线程同步通信,代码如下:

# *-* coding:gb2312 *-*
import threading
import time
stationName=("车站0","车站1","车站2","车站3","车站4","车站5","车站6")
currentStationIndex = -1
eventBusStop = threading.Event()
eventClosedDoor = threading.Event()
eventOpenedDoor = threading.Event()
stationCount = len(stationName)
class Passenger(threading.Thread):
  def __init__(self,no,getonStation,getoffStation):
    self.no =no
    self.getonStation=getonStation
    self.getoffStation=getoffStation
    threading.Thread.__init__(self)
  def run(self):
    bExit= False
    global currentStationIndex
    global stationCount
    bAlreadyGetOnStation = False
    while not bExit:
      eventOpenedDoor.wait()
      if self.getonStation == currentStationIndex and bAlreadyGetOnStation == False:
        print "乘客%d在%s上车" %(self.no,stationName[currentStationIndex])
        bAlreadyGetOnStation =True
      elif self.getoffStation == currentStationIndex:
        print "乘客%d在%s下车" %(self.no,stationName[currentStationIndex])
        bExit = True
      time.sleep(1)
class Driver(threading.Thread):
  def run(self):
    bExit= False
    global currentStationIndex
    global stationCount
    while not bExit:
      print "司机: 公交车开始行驶....."
      time.sleep(5)
      currentStationIndex += 1
      print "司机: 到站 ",stationName[currentStationIndex]
      eventBusStop.set()
      eventClosedDoor.wait()
      eventClosedDoor.clear()
      if currentStationIndex == stationCount-1:
        bExit= True
class Conductor(threading.Thread):
  def run(self):
    bExit= False
    global currentStationIndex
    global stationCount
    while not bExit:
      eventBusStop.wait()
      eventBusStop.clear()
      print "售票员打开车门:%s到了" %(stationName[currentStationIndex])
      eventOpenedDoor.set()
      time.sleep(5)
      print "售票员关闭车门"
      eventOpenedDoor.clear()
      eventClosedDoor.set()
      if currentStationIndex == stationCount-1:
        bExit = True
def test():
  passPool=[]
  passPool.append(Passenger(0,0,3))
  passPool.append(Passenger(1,1,3))
  passPool.append(Passenger(2,2,4))
  passPool.append(Passenger(3,0,5))
  passPool.append(Passenger(4,1,3))
  passPool.append(Passenger(5,2,4))
  passPool.append(Passenger(6,4,5))
  passPool.append(Passenger(7,0,2))
  passPool.append(Passenger(8,1,3))
  passPool.append(Conductor())
  passPool.append(Driver())
  leng = len(passPool)
  for i in range(leng):
    passPool[i].start()
if __name__=='__main__':
  test()

输出结果如下:

Python多线程经典问题之乘客做公交车算法实例

希望本文所述对大家Python程序设计有所帮助。

Python 相关文章推荐
python实现识别相似图片小结
Feb 22 Python
python生成器,可迭代对象,迭代器区别和联系
Feb 04 Python
Pyqt5实现英文学习词典
Jun 24 Python
python二维码操作:对QRCode和MyQR入门详解
Jun 24 Python
Django 模型类(models.py)的定义详解
Jul 19 Python
执行Django数据迁移时报 1091错误及解决方法
Oct 14 Python
python 画函数曲线示例
Dec 04 Python
tensorflow入门:TFRecordDataset变长数据的batch读取详解
Jan 20 Python
解决tensorflow添加ptb库的问题
Feb 10 Python
解决python 找不到module的问题
Feb 12 Python
python itsdangerous模块的具体使用方法
Feb 17 Python
selenium+headless chrome爬虫的实现示例
Jan 08 Python
利用pyinstaller或virtualenv将python程序打包详解
Mar 22 #Python
python条件变量之生产者与消费者操作实例分析
Mar 22 #Python
Python实现遍历目录的方法【测试可用】
Mar 22 #Python
Python简单操作sqlite3的方法示例
Mar 22 #Python
Python创建xml文件示例
Mar 22 #Python
用Python将IP地址在整型和字符串之间轻松转换
Mar 22 #Python
用python写一个windows下的定时关机脚本(推荐)
Mar 21 #Python
You might like
php的闭包(Closure)匿名函数详解
2015/02/22 PHP
PHP超牛逼无限极分类生成树方法
2015/05/11 PHP
ThinkPHP函数详解之M方法和R方法
2015/09/10 PHP
PHP 中常量的知识整理
2017/04/14 PHP
ecshop添加菜单及权限分配问题
2017/11/21 PHP
PHP实现的敏感词过滤方法示例
2019/03/06 PHP
通过下拉框的值来确定输入框是否可以为空的代码
2011/10/18 Javascript
jQuery判断密码强度实现思路及代码
2013/04/24 Javascript
深入理解JS中的变量及作用域、undefined与null
2014/03/04 Javascript
js获取微信版本号的方法
2015/05/12 Javascript
jQuery简单实现input文本框内灰色提示文本效果的方法
2015/12/02 Javascript
nodejs利用ajax实现网页无刷新上传图片实例代码
2017/06/06 NodeJs
从源码里了解vue中的nextTick的使用
2018/11/22 Javascript
微信小程序动态显示项目倒计时
2019/06/20 Javascript
微信小程序实现蒙版弹出窗功能
2019/09/17 Javascript
python中pycurl库的用法实例
2014/09/30 Python
python 写的一个爬虫程序源码
2016/02/28 Python
详解用Python实现自动化监控远程服务器
2019/05/18 Python
Django框架登录加上验证码校验实现验证功能示例
2019/05/23 Python
pyqt5 textEdit、lineEdit操作的示例代码
2020/08/12 Python
孕妇装中的著名品牌:Isabella Oliver(伊莎贝拉·奥利弗)
2016/10/31 全球购物
Forever 21美国官网:美国标志性快时尚品牌
2017/02/20 全球购物
介绍一下Java的安全机制
2012/06/28 面试题
我想声明一个指针并为它分配一些空间, 但却不行。这些代码有什么 问题?char *p; *p = malloc(10);
2016/10/06 面试题
通信工程专业女生个人求职信
2013/09/21 职场文书
电大自我鉴定范文
2013/10/01 职场文书
大学老师推荐信
2014/02/25 职场文书
菜篮子工程实施方案
2014/03/08 职场文书
最新结婚典礼主持词
2014/03/14 职场文书
机关门卫的岗位职责
2014/04/29 职场文书
贷款工作证明模板
2015/06/12 职场文书
旅行社计调工作总结
2015/08/12 职场文书
企业反腐倡廉心得体会
2015/08/15 职场文书
golang goroutine顺序输出方式
2021/04/29 Golang
Python 实现定积分与二重定积分的操作
2021/05/26 Python
PC版《死亡搁浅导剪版》现已发售 展开全新的探险
2022/04/03 其他游戏