Python模拟哲学家进餐问题
生活随笔
收集整理的這篇文章主要介紹了
Python模拟哲学家进餐问题
小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.
有兩個(gè)哲學(xué)家坐在桌子上,桌子上放了兩只筷子,編號分別是a和b,只有同時(shí)得到a、b兩只筷子時(shí)哲學(xué)家才能吃飯,如果筷子a被哲學(xué)家1號搶到了,筷子b被哲學(xué)家2號搶到了,此時(shí)兩位哲學(xué)家都想要得到對方手中的筷子然后去吃一口飯,但是又不肯主動放下自己手中的筷子給對方,此時(shí)就進(jìn)入了漫長的等待對方釋放自己想要的“資源”的過程,也就產(chǎn)生了死鎖。
import threading import time# 創(chuàng)建兩個(gè)鎖 lock_a=threading.Lock() lock_b=threading.Lock()def philosopher_a():for i in range(99):# 上鎖lock_a.acquire()print('哲學(xué)家a給lock_a加鎖,搶到了筷子a')lock_b.acquire()print(f'哲學(xué)家a給lock_b加鎖,搶到了筷子b,ab兩只筷子到手,吃第{i+1}口飯')# 解鎖lock_a.release()print('哲學(xué)家a給lock_a解鎖,釋放了筷子a')lock_b.release()print('哲學(xué)家a給lock_b解鎖,釋放了筷子b')# time.sleep(0.5)def philosopher_b():for i in range(99):# 上鎖lock_b.acquire()print('哲學(xué)家b給lock_b加鎖,搶到了筷子b')lock_a.acquire()print(f'哲學(xué)家b給lock_a加鎖,搶到了筷子a,ab兩只筷子到手,吃第{i+1}口飯')# 解鎖lock_b.release()print('哲學(xué)家b給lock_b解鎖,釋放了筷子b')lock_a.release()print('哲學(xué)家b給lock_a解鎖,釋放了筷子a')# time.sleep(0.5)if __name__ == '__main__':t1=threading.Thread(target=philosopher_a)t2=threading.Thread(target=philosopher_b)t1.start()t2.start()?
總結(jié)
以上是生活随笔為你收集整理的Python模拟哲学家进餐问题的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: Python实现学生信息管理(面向对象)
- 下一篇: Python中*args 和**kwar