pythonjw 2014-04-26
关于设计模式中的观察者模式,定义如下(维基百科):
^察者模式(有r又被Q榘l布/模式)是wO模式的一N。在此N模式中,一目宋锛芾硭邢嘁漓端挠^察者物件,K且在它本身的B改r主影l出通知。@通常透^呼叫各^察者所提供的方法F。此N模式通常被用作事件硐到y。
简单来说,一个被观察者有很多观察者,被观察者的状态的改变会引起所有观察者的响应操作。
那么我们用Python2.7来实现观察者模式。
Python中的集合set
集合(set),类似于列表(list),但是它没有重复的元素,它的doc内容如下:
代码如下:
>>> print set.__doc__ set() -> new empty set object set(iterable) -> new set object Build an unordered collection of unique elements.
代码如下:
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'])
代码如下:
>>> print set([1,2,3,3]) set([1, 2, 3])
一个简单的观察者模式的实现
代码如下:
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()
代码如下:
set([<__main__.Observer object at 0xb74627cc>, <__main__.Observer object at 0xb74627ec>]) hi, i am foo01 hi, i am foo02
代码如下:
for ob in observers: ob.update()
当然,这种实现并不好――被观察者也应该是一个实例。
更加完善的观察者模式实现
代码如下:
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()
代码如下:
hi, i am ob01 hello,i am ob02