Python多線程經(jīng)典問題之乘客做公交車算法實(shí)例
本文實(shí)例講述了Python多線程經(jīng)典問題之乘客做公交車算法。分享給大家供大家參考,具體如下:
問題描述:
乘客乘坐公交車問題,司機(jī),乘客,售票員協(xié)同工作,通過多線程模擬三者的工作。
司機(jī):開車,停車
售票員:打開車門,關(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 "司機(jī): 公交車開始行駛....." 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 "售票員打開車門:%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進(jìn)程與線程操作技巧總結(jié)》、《Python Socket編程技巧總結(jié)》、《Python圖片操作技巧總結(jié)》、《Python數(shù)據(jù)結(jié)構(gòu)與算法教程》、《Python函數(shù)使用技巧總結(jié)》、《Python字符串操作技巧匯總》、《Python入門與進(jìn)階經(jīng)典教程》及《Python文件與目錄操作技巧匯總》
希望本文所述對(duì)大家Python程序設(shè)計(jì)有所幫助。
- Python使用回溯法子集樹模板解決爬樓梯問題示例
- Python解決走迷宮問題算法示例
- Python使用Dijkstra算法實(shí)現(xiàn)求解圖中最短路徑距離問題詳解
- Python基于Floyd算法求解最短路徑距離問題實(shí)例詳解
- Python使用遺傳算法解決最大流問題
- 淺談Python實(shí)現(xiàn)貪心算法與活動(dòng)安排問題
- Python數(shù)據(jù)結(jié)構(gòu)與算法之使用隊(duì)列解決小貓釣魚問題
- Python基于動(dòng)態(tài)規(guī)劃算法解決01背包問題實(shí)例
- Python基于貪心算法解決背包問題示例
- Python3爬樓梯算法示例
相關(guān)文章
不到20行代碼用Python做一個(gè)智能聊天機(jī)器人
小編先向大家介紹一下本次運(yùn)用到的python庫,本次項(xiàng)目主要運(yùn)用到的庫有wxpy和chatterbot。對(duì)Python做一個(gè)智能聊天機(jī)器人的相關(guān)知識(shí)感興趣的朋友跟隨小編一起看看吧2019-04-04Django values()和value_list()的使用
這篇文章主要介紹了Django values()和value_list()的使用,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2020-03-03Python?Timer和TimerFPS計(jì)時(shí)工具類
這篇文章主要介紹了Python?Timer和TimerFPS計(jì)時(shí)工具類,文章分享得代碼內(nèi)容詳細(xì),具有一的的參考價(jià)值,需要的小伙伴可以參考一下2022-03-03python自動(dòng)化發(fā)送郵件實(shí)例講解
在本篇文章里小編給大家分享了一篇關(guān)于python自動(dòng)化發(fā)送郵件實(shí)例講解內(nèi)容,有興趣的朋友們可以學(xué)習(xí)參考下。2021-01-01python 實(shí)現(xiàn)將list轉(zhuǎn)成字符串,中間用空格隔開
今天小編就為大家分享一篇python 實(shí)現(xiàn)將list轉(zhuǎn)成字符串,中間用空格隔開,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2019-12-12python開發(fā)利器之ulipad的使用實(shí)踐
Ulipad是一個(gè)國人limodou編寫的專業(yè)Python編輯器,它基于wxpython開發(fā)的GUI(圖形化界面)。下面這篇文章主要介紹了python開發(fā)利器之ulipad的使用實(shí)踐,文中介紹的非常詳細(xì),對(duì)大家具有一定的參考價(jià)值,需要的朋友們下面來一起看看吧。2017-03-03