python實現(xiàn)AutoResetEvent類的阻塞模式方法解析
更新時間:2012年11月16日 11:21:43 作者:
AutoResetEvent :當(dāng)某個線程執(zhí)行到WaitOne()方法時,該線程則會處于阻塞模式,當(dāng)被調(diào)用了Set()方法,阻塞的線程則會繼續(xù)向下執(zhí)行,其狀態(tài)立即被自動設(shè)置為阻塞模式
搞過C#多線程的人對其中的AutoResetEvent和ManualResetEvent這兩個類都理解,其中的WaitOne()方法和Set()以及Reset()方法在線程同步當(dāng)中用的是比較多的。
AutoResetEvent :當(dāng)某個線程執(zhí)行到WaitOne()方法時,該線程則會處于阻塞模式,當(dāng)被調(diào)用了Set()方法,阻塞的線程則會繼續(xù)向下執(zhí)行,其狀態(tài)立即被自動設(shè)置為阻塞模式。
ManualResetEvent :當(dāng)某個線程執(zhí)行到WaitOne()方法時,該線程則會處于阻塞模式,當(dāng)被調(diào)用了Set()方法,阻塞的線程則會繼續(xù)向下執(zhí)行,其狀態(tài)不會被自動設(shè)置為阻塞模式,必須調(diào)用其Reset()方法才會將其狀態(tài)設(shè)置為阻塞模式。
在python中threading模塊下也有一個類似的線程阻塞模式的類threading.Event(),這個類類似于C#的ManualResetEvent類,在調(diào)用set()方法后不能自動變?yōu)樽枞J?。有些時候我們在開發(fā)項目當(dāng)中需要這種自動的阻塞模式,我在項目當(dāng)中也遇到過這種需求,就嘗試自己寫了個類似的類,吧代碼貼出來分享下,代碼不多,有不對或者是不合理的地方希望大蝦們或者是前輩們能指出,謝謝!
代碼如下:
# encoding: UTF-8
import threading
class AutoEvent:
def __init__(self):
self.event = None
self.is_wait = False # 是否處于阻塞狀態(tài)
def Wait(self,timeout=None):
if not self.is_wait:
self.is_wait = True
self.event = threading.Event() # 實例化threading.Event()對象
self.event.wait(timeout=timeout) # 調(diào)用threading.Event().wait()方法,讓線程處于阻塞狀態(tài)
del self.event # 釋放對象
def Set(self):
if not self.is_wait:raise 'must be invoke Wait() method before Set()'
self.is_wait = False
self.event.set() # 調(diào)用threading.Event().set()方法,讓線程處于繼續(xù)
下面是Demo,用來測試的:
import wx
autoEvent = AutoEvent() # 實例化MamualEvent對象
class TestDialog(wx.Dialog):
def __init__(self, parent):
wx.Dialog.__init__(self, parent, -1)
b = wx.Button(self, -1, "print", (50, 140))
self.Bind(wx.EVT_BUTTON, self.OnPrint, b)
self.thread = threading.Thread(target=self.work)
self.thread.start()
def work(self):
while True:
print 3
autoEvent.Wait() # 阻塞
def OnPrint(self, evt):
autoEvent.Set() # 繼續(xù)
if __name__=="__main__":
app = wx.App()
f = TestDialog(parent=None)
f.Show()
app.MainLoop()
當(dāng)程序執(zhí)行時,首先會打印出來個 ‘3',后面沒點擊一下print按鈕,則會打印一個 '3'
測試成功。
注意:如果你將Demo代碼中的 autoEvent.Wait()和autoEvent.Set() 改成 threading.Event()類的wait()和set()方法,結(jié)果會如下:當(dāng)程序執(zhí)行時,會打印個'3' ,后面點擊print按鈕后,會一直循環(huán)打印'3'
AutoResetEvent :當(dāng)某個線程執(zhí)行到WaitOne()方法時,該線程則會處于阻塞模式,當(dāng)被調(diào)用了Set()方法,阻塞的線程則會繼續(xù)向下執(zhí)行,其狀態(tài)立即被自動設(shè)置為阻塞模式。
ManualResetEvent :當(dāng)某個線程執(zhí)行到WaitOne()方法時,該線程則會處于阻塞模式,當(dāng)被調(diào)用了Set()方法,阻塞的線程則會繼續(xù)向下執(zhí)行,其狀態(tài)不會被自動設(shè)置為阻塞模式,必須調(diào)用其Reset()方法才會將其狀態(tài)設(shè)置為阻塞模式。
在python中threading模塊下也有一個類似的線程阻塞模式的類threading.Event(),這個類類似于C#的ManualResetEvent類,在調(diào)用set()方法后不能自動變?yōu)樽枞J?。有些時候我們在開發(fā)項目當(dāng)中需要這種自動的阻塞模式,我在項目當(dāng)中也遇到過這種需求,就嘗試自己寫了個類似的類,吧代碼貼出來分享下,代碼不多,有不對或者是不合理的地方希望大蝦們或者是前輩們能指出,謝謝!
代碼如下:
復(fù)制代碼 代碼如下:
# encoding: UTF-8
import threading
class AutoEvent:
def __init__(self):
self.event = None
self.is_wait = False # 是否處于阻塞狀態(tài)
def Wait(self,timeout=None):
if not self.is_wait:
self.is_wait = True
self.event = threading.Event() # 實例化threading.Event()對象
self.event.wait(timeout=timeout) # 調(diào)用threading.Event().wait()方法,讓線程處于阻塞狀態(tài)
del self.event # 釋放對象
def Set(self):
if not self.is_wait:raise 'must be invoke Wait() method before Set()'
self.is_wait = False
self.event.set() # 調(diào)用threading.Event().set()方法,讓線程處于繼續(xù)
下面是Demo,用來測試的:
復(fù)制代碼 代碼如下:
import wx
autoEvent = AutoEvent() # 實例化MamualEvent對象
class TestDialog(wx.Dialog):
def __init__(self, parent):
wx.Dialog.__init__(self, parent, -1)
b = wx.Button(self, -1, "print", (50, 140))
self.Bind(wx.EVT_BUTTON, self.OnPrint, b)
self.thread = threading.Thread(target=self.work)
self.thread.start()
def work(self):
while True:
print 3
autoEvent.Wait() # 阻塞
def OnPrint(self, evt):
autoEvent.Set() # 繼續(xù)
if __name__=="__main__":
app = wx.App()
f = TestDialog(parent=None)
f.Show()
app.MainLoop()
當(dāng)程序執(zhí)行時,首先會打印出來個 ‘3',后面沒點擊一下print按鈕,則會打印一個 '3'
測試成功。
注意:如果你將Demo代碼中的 autoEvent.Wait()和autoEvent.Set() 改成 threading.Event()類的wait()和set()方法,結(jié)果會如下:當(dāng)程序執(zhí)行時,會打印個'3' ,后面點擊print按鈕后,會一直循環(huán)打印'3'
您可能感興趣的文章:
- Python多線程編程(八):使用Event實現(xiàn)線程間通信
- Python多線程同步Lock、RLock、Semaphore、Event實例
- Python多進(jìn)程同步Lock、Semaphore、Event實例
- python多線程threading.Lock鎖用法實例
- 詳解Python中的多線程編程
- python多線程編程中的join函數(shù)使用心得
- 淺析Python中的多進(jìn)程與多線程的使用
- python通過線程實現(xiàn)定時器timer的方法
- 理解python多線程(python多線程簡明教程)
- python殺死一個線程的方法
- Python threading多線程編程實例
- 淺析Python多線程下的變量問題
- Python編程之event對象的用法實例分析
相關(guān)文章
詳解C#中多態(tài)性學(xué)習(xí)/虛方法/抽象方法和接口的用法
這篇文章主要為大家詳細(xì)介紹了C#中多態(tài)性學(xué)習(xí)、虛方法、抽象方法和接口的用法的相關(guān)知識,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以了解一下2023-03-03c#循環(huán)中產(chǎn)生偽隨機(jī)數(shù)
在循環(huán)中產(chǎn)生多個隨機(jī)數(shù),容易出現(xiàn)連續(xù)相同的數(shù)據(jù),最終的多個隨機(jī)數(shù)并不隨機(jī),而是帶有某種規(guī)律性。2010-06-06unity實現(xiàn)虛擬搖桿控制Virtual Joystick
這篇文章主要為大家詳細(xì)介紹了unity實現(xiàn)虛擬搖桿控制Virtual Joystick,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下2020-04-04