本文实例讲述了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 Socket编程技巧总结》、《Python图片操作技巧总结》、《Python数据结构与算法教程》、《Python函数使用技巧总结》、《Python字符串操作技巧汇总》、《Python入门与进阶经典教程》及《Python文件与目录操作技巧汇总》
希望本文所述对大家Python程序设计有所帮助。
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件!
如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
暂无“Python多线程经典问题之乘客做公交车算法实例”评论...
更新动态
2025年11月05日
2025年11月05日
- 小骆驼-《草原狼2(蓝光CD)》[原抓WAV+CUE]
- 群星《欢迎来到我身边 电影原声专辑》[320K/MP3][105.02MB]
- 群星《欢迎来到我身边 电影原声专辑》[FLAC/分轨][480.9MB]
- 雷婷《梦里蓝天HQⅡ》 2023头版限量编号低速原抓[WAV+CUE][463M]
- 群星《2024好听新歌42》AI调整音效【WAV分轨】
- 王思雨-《思念陪着鸿雁飞》WAV
- 王思雨《喜马拉雅HQ》头版限量编号[WAV+CUE]
- 李健《无时无刻》[WAV+CUE][590M]
- 陈奕迅《酝酿》[WAV分轨][502M]
- 卓依婷《化蝶》2CD[WAV+CUE][1.1G]
- 群星《吉他王(黑胶CD)》[WAV+CUE]
- 齐秦《穿乐(穿越)》[WAV+CUE]
- 发烧珍品《数位CD音响测试-动向效果(九)》【WAV+CUE】
- 邝美云《邝美云精装歌集》[DSF][1.6G]
- 吕方《爱一回伤一回》[WAV+CUE][454M]
