Python設(shè)計(jì)模式之觀察者模式實(shí)例
關(guān)于設(shè)計(jì)模式中的觀察者模式,定義如下(維基百科):
觀察者模式(有時(shí)又被稱為發(fā)布/訂閱模式)是軟體設(shè)計(jì)模式的一種。在此種模式中,一個(gè)目標(biāo)物件管理所有相依於它的觀察者物件,並且在它本身的狀態(tài)改變時(shí)主動(dòng)發(fā)出通知。這通常透過(guò)呼叫各觀察者所提供的方法來(lái)實(shí)現(xiàn)。此種模式通常被用來(lái)實(shí)作事件處理系統(tǒng)。
簡(jiǎn)單來(lái)說(shuō),一個(gè)被觀察者有很多觀察者,被觀察者的狀態(tài)的改變會(huì)引起所有觀察者的響應(yīng)操作。
那么我們用Python2.7來(lái)實(shí)現(xiàn)觀察者模式。
Python中的集合set
集合(set),類似于列表(list),但是它沒(méi)有重復(fù)的元素,它的doc內(nèi)容如下:
>>> print set.__doc__
set() -> new empty set object
set(iterable) -> new set object
Build an unordered collection of unique elements.
下面是在ipython中進(jìn)行的幾個(gè)簡(jiǎn)單的集合操作。
In [1]: myset = set()
In [2]: myset.add(1)
In [3]: myset.add(2)
In [4]: myset.add('s')
In [5]: print myset
set([1, 2, 's'])
In [6]: myset.add('s')
In [7]: print myset
set([1, 2, 's'])
In [8]: myset.remove(3)
---------------------------------------------------------------------------
KeyError Traceback (most recent call last)
<ipython-input-8-a93073f8a2af> in <module>()
----> 1 myset.remove(3)
KeyError: 3
In [9]: myset.remove(1)
In [10]: print myset
set([2, 's'])
通過(guò)內(nèi)置的set()可以產(chǎn)生一個(gè)空的集合對(duì)象,也可以在set中傳入一些參數(shù),例如一個(gè)列表:
>>> print set([1,2,3,3])
set([1, 2, 3])
最常用的方法就是add和remove了,更多內(nèi)容可以參考http://docs.python.org/2/library/stdtypes.html#set。
一個(gè)簡(jiǎn)單的觀察者模式的實(shí)現(xiàn)
class Observer(object):
def __init__(self, s):
self.s = s
def update(self):
print self.s
if __name__ == '__main__':
foo01 = Observer("hi, i am foo01")
foo02 = Observer("hi, i am foo02")
observers = set()
observers.add(foo01)
observers.add(foo01)
observers.add(foo02)
print observers
for ob in observers:
ob.update()
下面是運(yùn)行結(jié)果:
set([<__main__.Observer object at 0xb74627cc>, <__main__.Observer object at 0xb74627ec>])
hi, i am foo01
hi, i am foo02
運(yùn)行結(jié)果中第一行是集合observers的內(nèi)容,其包含了兩個(gè)Observer實(shí)例,這些實(shí)例所處的內(nèi)存地址在每次運(yùn)行時(shí)可能有不同。而
for ob in observers:
ob.update()
就可以看成多個(gè)觀察者產(chǎn)生響應(yīng)。
當(dāng)然,這種實(shí)現(xiàn)并不好——被觀察者也應(yīng)該是一個(gè)實(shí)例。
更加完善的觀察者模式實(shí)現(xiàn)
class ObserverInterface(object):
def __init__(self):
pass
def update(self):
pass
class SubjectInterface(object):
def __init__(self):
self.observers = set()
def addObserver(self, ob):
self.observers.add(ob)
def delObserver(self, ob):
self.observers.remove(ob)
def notifyObservers(self):
for ob in self.observers:
ob.update()
class Observer01(ObserverInterface):
def __init__(self, s):
self.s = s
def update(self):
print self.s
class Observer02(ObserverInterface):
def __init__(self, num1, num2):
self.num1 = num1
self.num2 = num2
def update(self):
print self.num1 + self.num2
class Subject01(SubjectInterface):
def __init__(self):
SubjectInterface.__init__(self)
if __name__ == '__main__':
ob01 = Observer01("hi, i am ob01")
ob02 = Observer02("hello,","i am ob02")
observers = set()
sb01 = Subject01()
sb01.addObserver(ob01)
sb01.addObserver(ob02)
sb01.notifyObservers()
運(yùn)行結(jié)果如下:
hi, i am ob01
hello,i am ob02
相關(guān)文章
Python大數(shù)據(jù)用Numpy Array的原因解讀
一個(gè)Numpy數(shù)組由許多值組成,所有值的類型是相同的,Numpy 是Python科學(xué)計(jì)算的一個(gè)核心模塊,本文重點(diǎn)給大家介紹Python大數(shù)據(jù)Numpy Array的相關(guān)知識(shí),感興趣的朋友一起看看吧2022-02-02Python使用SQLAlchemy模塊實(shí)現(xiàn)操作數(shù)據(jù)庫(kù)
SQLAlchemy 是用Python編程語(yǔ)言開(kāi)發(fā)的一個(gè)開(kāi)源項(xiàng)目,它提供了SQL工具包和ORM對(duì)象關(guān)系映射工具,使用SQLAlchemy可以實(shí)現(xiàn)高效和高性能的數(shù)據(jù)庫(kù)訪問(wèn),下面我們就來(lái)學(xué)習(xí)一下SQLAlchemy模塊的具體應(yīng)用吧2023-11-11Python讀取JSON數(shù)據(jù)操作實(shí)例解析
這篇文章主要介紹了Python讀取JSON數(shù)據(jù)操作實(shí)例解析,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-05-05Python使用xlrd實(shí)現(xiàn)讀取合并單元格
這篇文章主要介紹了Python使用xlrd實(shí)現(xiàn)讀取合并單元格,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-07-07PyTorch中Tensor的數(shù)據(jù)統(tǒng)計(jì)示例
今天小編就為大家分享一篇PyTorch中Tensor的數(shù)據(jù)統(tǒng)計(jì)示例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-02-02Python MySQLdb 執(zhí)行sql語(yǔ)句時(shí)的參數(shù)傳遞方式
這篇文章主要介紹了Python MySQLdb 執(zhí)行sql語(yǔ)句時(shí)的參數(shù)傳遞方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-03-03Django實(shí)現(xiàn)auth模塊下的登錄注冊(cè)與注銷功能
這篇文章主要介紹了Django實(shí)現(xiàn)auth模塊下的登錄注冊(cè)與注銷功能,本文給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2019-10-10