Python多線程經(jīng)典問題之乘客做公交車算法實例
本文實例講述了Python多線程經(jīng)典問題之乘客做公交車算法。分享給大家供大家參考,具體如下:
問題描述:
乘客乘坐公交車問題,司機,乘客,售票員協(xié)同工作,通過多線程模擬三者的工作。
司機:開車,停車
售票員:打開車門,關(guān)閉車門
乘客:上車,下車
用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 "售票員關(guān)閉車門"
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()
輸出結(jié)果如下:

更多關(guān)于Python相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《Python進程與線程操作技巧總結(jié)》、《Python Socket編程技巧總結(jié)》、《Python圖片操作技巧總結(jié)》、《Python數(shù)據(jù)結(jié)構(gòu)與算法教程》、《Python函數(shù)使用技巧總結(jié)》、《Python字符串操作技巧匯總》、《Python入門與進階經(jīng)典教程》及《Python文件與目錄操作技巧匯總》
希望本文所述對大家Python程序設(shè)計有所幫助。
相關(guān)文章
Django values()和value_list()的使用
這篇文章主要介紹了Django values()和value_list()的使用,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-03-03
python 實現(xiàn)將list轉(zhuǎn)成字符串,中間用空格隔開
今天小編就為大家分享一篇python 實現(xiàn)將list轉(zhuǎn)成字符串,中間用空格隔開,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-12-12

