相同內容多種展示形式
乙個內容, 可以有多種展示形式. 例如某各資料, 既可以用**, 也可以用柱狀圖,餅狀圖來展示. 如何保證內容與展示統一, 且即時更新.
observer
將內容與展示分開, 一旦內容有改變, 就通知展示回來取內容並重新重新整理.
uml圖
內容與展示分隔開
將內容與展示分隔開, 保證了各個展示的內容統一.
即時更新
內容一旦改變, 各展示形式都可以即時更新.
需求描述
系統內有乙個計時器(模型,沒有介面),這個計時器驅動兩個形式的時鐘介面,乙個數字時鐘,乙個模擬時鐘.
uml圖
將內容與展示的形式分割開, 單獨設計. 內容一旦改變就通知展示重新取內容並更新. 展示形式像是乙個觀測者, 觀察內容的變動.
python
observer.py:
# coding: utf-8
""" example of observer pattern.
@author: liu weijie
@data: 2015-12-25
需求:系統內有乙個計時器(模型,沒有介面),這個計時器驅動兩個形式的時鐘介面,乙個數字時鐘,乙個模擬時鐘.
"""class subject(object):
""" subject """
def __init__(self):
self.observers =
def attach(self, observer_add):
def detach(self, observer_del):
self.observers.remove(observer_del)
def notify(self):
for ob in self.observers:
ob.update(self)
class observer(object):
""" observer """
def __init__(self):
pass
def update(self, subject):
pass
class clocktimer(subject):
""" concretesubject """
def __init__(self, hour_in, minute_in, second_in):
super(clocktimer, self).__init__()
self._hour = hour_in
self._minute = minute_in
self._second = second_in
def get_hour(self):
return self._hour
def set_hour(self, hour_in):
self._hour = hour_in
def get_minute(self):
return self._minute
def set_minutr(self, minute_in):
self._minute = minute_in
def get_second(self):
return self._second
def set_second(self, second_in):
self._second = second_in
class digtalclock(observer):
""" concreteobserver """
def __init__(self, subject):
self._hour = subject.get_hour()
self._minute = subject.get_minute()
self._second = subject.get_second()
def update(self, subject):
self._hour = subject.get_hour()
self._minute = subject.get_minute()
self._second = subject.get_second()
def draw(self):
print "digtalclock:", self._hour, ":", self._minute, ":", self._second, "\n"
class analogyclock(observer):
""" concreteobserver """
def __init__(self, subject):
self._hour = subject.get_hour()
self._minute = subject.get_minute()
self._second = subject.get_second()
def update(self, subpreject):
self._hour = subject.get_hour()
self._minute = subject.get_minute()
self._second = subject.get_second()
def draw(self):
print "analogylock:", self._hour, ":", self._minute, ":", self._second, "\n"
if __name__ == "__main__":
# init
clock_timer = clocktimer(6, 0, 0)
digtal_clock = digtalclock(clock_timer)
analogy_clock = analogyclock(clock_timer)
clock_timer.attach(digtal_clock)
clock_timer.attach(analogy_clock)
digtal_clock.draw()
analogy_clock.draw()
# an hour later
clock_timer.set_hour(7)
clock_timer.notify()
digtal_clock.draw()
analogy_clock.draw()
# an hour later
clock_timer.detach(analogy_clock)
clock_timer.set_hour(8)
clock_timer.notify()
digtal_clock.draw()
analogy_clock.draw()
設計模式7 觀察者模式
定義 也叫發布訂閱模型。觀察者模式定義物件間一種一對多的依賴關係,使得每當乙個物件改變狀態,則所有依賴於它的物件都會得到通知並被自動更新。觀察者模式的優點 1 觀察者和被觀察者之間是抽象耦合 2 建立一套觸發機制 缺點 開發效率和除錯比較複雜,有多個觀察者時要考慮使用非同步的方式,否則乙個觀察者卡殼...
python 設計模式 觀察者 觀察者設計模式
在觀察者設計模式這種模式中,物件被表示為等待事件觸發的觀察者。一旦發生指定的事件,觀察者就會關注該主體。當事件發生時,主體告訴觀察者它已經發生。以下uml圖表示觀察者模式 如何實現觀察者模式?現在讓我們來看看如何實現觀察者模式。參考以下實現 import threading import time ...
設計模式 觀察者模式
觀察者模式定義了物件間一對多的依賴關係,乙個物件發生變化時,所有依賴它的物件都得到通知並被自動更新。本文主要闡述觀察者模式在分布式scada人機介面中的使用,利用這種模式使得人機介面顯示效率更高。發布者 郵局 觀察者 參與者 讀者 訂閱者 當郵局收到報社新雜誌的時候,即郵局狀態發生了改變,於是郵局把...