Python多線程經(jīng)典問(wèn)題之乘客做公交車(chē)算法實(shí)例
本文實(shí)例講述了Python多線程經(jīng)典問(wèn)題之乘客做公交車(chē)算法。分享給大家供大家參考,具體如下:
問(wèn)題描述:
乘客乘坐公交車(chē)問(wèn)題,司機(jī),乘客,售票員協(xié)同工作,通過(guò)多線程模擬三者的工作。
司機(jī):開(kāi)車(chē),停車(chē)
售票員:打開(kāi)車(chē)門(mén),關(guān)閉車(chē)門(mén)
乘客:上車(chē),下車(chē)
用Python的Event做線程同步通信,代碼如下:
# *-* coding:gb2312 *-*
import threading
import time
stationName=("車(chē)站0","車(chē)站1","車(chē)站2","車(chē)站3","車(chē)站4","車(chē)站5","車(chē)站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上車(chē)" %(self.no,stationName[currentStationIndex])
bAlreadyGetOnStation =True
elif self.getoffStation == currentStationIndex:
print "乘客%d在%s下車(chē)" %(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 "司機(jī): 公交車(chē)開(kāi)始行駛....."
time.sleep(5)
currentStationIndex += 1
print "司機(jī): 到站 ",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 "售票員打開(kāi)車(chē)門(mén):%s到了" %(stationName[currentStationIndex])
eventOpenedDoor.set()
time.sleep(5)
print "售票員關(guān)閉車(chē)門(mé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進(jìn)程與線程操作技巧總結(jié)》、《Python Socket編程技巧總結(jié)》、《Python圖片操作技巧總結(jié)》、《Python數(shù)據(jù)結(jié)構(gòu)與算法教程》、《Python函數(shù)使用技巧總結(jié)》、《Python字符串操作技巧匯總》、《Python入門(mén)與進(jìn)階經(jīng)典教程》及《Python文件與目錄操作技巧匯總》
希望本文所述對(duì)大家Python程序設(shè)計(jì)有所幫助。
- Python使用回溯法子集樹(shù)模板解決爬樓梯問(wèn)題示例
- Python解決走迷宮問(wèn)題算法示例
- Python使用Dijkstra算法實(shí)現(xiàn)求解圖中最短路徑距離問(wèn)題詳解
- Python基于Floyd算法求解最短路徑距離問(wèn)題實(shí)例詳解
- Python使用遺傳算法解決最大流問(wèn)題
- 淺談Python實(shí)現(xiàn)貪心算法與活動(dòng)安排問(wèn)題
- Python數(shù)據(jù)結(jié)構(gòu)與算法之使用隊(duì)列解決小貓釣魚(yú)問(wèn)題
- Python基于動(dòng)態(tài)規(guī)劃算法解決01背包問(wèn)題實(shí)例
- Python基于貪心算法解決背包問(wèn)題示例
- Python3爬樓梯算法示例
相關(guān)文章
詳細(xì)總結(jié)Python常見(jiàn)的安全問(wèn)題
今天帶各位學(xué)習(xí)一下Python安全問(wèn)題,文中介紹的非常詳細(xì),對(duì)正在學(xué)習(xí)python的小伙伴有很好地幫助,需要的朋友可以參考下2021-05-05
pytorch實(shí)現(xiàn)特殊的Module--Sqeuential三種寫(xiě)法
今天小編就為大家分享一篇pytorch實(shí)現(xiàn)特殊的Module--Sqeuential三種寫(xiě)法。具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-01-01
Python爬蟲(chóng)實(shí)戰(zhàn)之虎牙視頻爬取附源碼
讀萬(wàn)卷書(shū)不如行萬(wàn)里路,學(xué)的扎不扎實(shí)要通過(guò)實(shí)戰(zhàn)才能看出來(lái),本篇文章手把手帶你爬取虎牙短視頻數(shù)據(jù),大家可以在實(shí)戰(zhàn)過(guò)程中查缺補(bǔ)漏,加深學(xué)習(xí)2021-10-10
簡(jiǎn)單介紹Python中用于求最小值的min()方法
這篇文章主要介紹了簡(jiǎn)單介紹Python中用于求最小值的min()方法,是Python入門(mén)中的基礎(chǔ)知識(shí),需要的朋友可以參考下2015-05-05
超全面python常見(jiàn)報(bào)錯(cuò)以及解決方案梳理必收藏
使用python難免會(huì)出現(xiàn)各種各樣的報(bào)錯(cuò),以下是Python常見(jiàn)的報(bào)錯(cuò)以及解決方法(持續(xù)更新),快進(jìn)入收藏吃灰吧2022-03-03
Python激活A(yù)naconda環(huán)境變量的詳細(xì)步驟
今天給大家分享Python激活A(yù)naconda環(huán)境變量的詳細(xì)步驟,激活A(yù)naconda環(huán)境變量分為簡(jiǎn)潔版和詳細(xì)版,簡(jiǎn)潔版只需要通過(guò)輸入命令進(jìn)行配置即可,詳細(xì)版本文通過(guò)圖文步驟給大家介紹的非常詳細(xì),需要的朋友參考下吧2021-06-06

