IT@程序员猿媛

python设计模式

2019-06-01  本文已影响3人  凌航

观察者模式

python观察者模式是一种设计模式
需求:员工上班在偷偷看股票,拜托前台一旦老板进来,就通知他们,让他们停止看股票。
这里有两类人,一类是观察者,即员工,一类是通知者,即前台,员工在观察前台的状态,前台负责通知员工最新的动态。


#encoding=utf-8
__author__ = 'kevinlu1010@qq.com'
from abc import ABCMeta, abstractmethod

class Subject():
    __metaclass__ = ABCMeta
    observers=[]
    status=''
    @abstractmethod
    def attach(self,observer):
        pass
    @abstractmethod
    def detach(self,observer):
        pass
    @abstractmethod
    def notify(self):
        pass

class Observer():
    __metaclass__ = ABCMeta
    def __init__(self,name,sub):
        self.name=name
        self.sub=sub
    @abstractmethod
    def update(self):
        pass

class Boss(Subject):
    def __init__(self):
        pass
    def attach(self,observer):
        self.observers.append(observer)

    def detach(self,observer):
        self.observers.remove(observer)
    def notify(self):
        for observer in self.observers:
            observer.update()

class StockObserver(Observer):
    def update(self):
        print '%s,%s停止看股票'%(self.sub.status,self.name)
class NBAObserver(Observer):
    def update(self):
        print '%s,%s停止看NBA'%(self.sub.status,self.name)

if __name__=='__main__':
    boss=Boss()
    observe1=StockObserver('张三',boss)
    observe2=NBAObserver('李四',boss)
    boss.attach(observe1)
    boss.attach(observe2)
    boss.detach(observe2)
    boss.status='我是老板,我来了'
    boss.notify()

如果觉得这个有点复杂没看懂,那就看下面这个简单一点的

# 设计模式:一种通用的解决方案
# 观察者模式

class Observer:
    """
    观察者
    """
    def __init__(self, name):
        self.name = name

    def update(self, msg):
        print(self.name + '收到消息:' + msg)

class Subject:
    """

    """
    def __init__(self):
        self.observers = []

    def add_observer(self, observer):
        self.observers.append(observer)

    def remove_observer(self, observer):
        self.observers.remove(observer)

    def notify(self, msg):
        for observer in self.observers:
            observer.update(msg)

xiaoming = Observer('xiaoming')
lihua = Observer('lihua')

rain = Subject()
rain.add_observer(xiaoming)
rain.add_observer(lihua)
rain.notify('下雨了。。。')
rain.remove_observer(lihua)

rain.notify("打雷了")

单例模式

单例模式(Singleton Pattern)是一种常用的软件设计模式,该模式的主要目的是确保某一个类只有一个实例存在。当你希望在整个系统中,某个类只能出现一个实例时,单例对象就能派上用场。
比如,某个服务器程序的配置信息存放在一个文件中,客户端通过一个 AppConfig 的类来读取配置文件的信息。如果在程序运行期间,有很多地方都需要使用配置文件的内容,也就是说,很多地方都需要创建 AppConfig 对象的实例,这就导致系统中存在多个 AppConfig 的实例对象,而这样会严重浪费内存资源,尤其是在配置文件内容很多的情况下。事实上,类似 AppConfig 这样的类,我们希望在程序运行期间只存在一个实例对象。这里我们讲解一个单例模式的实现方法——通过重写系统创建对象时分类内存的函数new

class S:
    instance = None
    # __new__方法用来制作单例
    def __new__(cls, *args, **kwargs):
        if S.instance == None:
            S.instance = super().__new__(cls) # 这句话是用来分配内存的,
        return S.instance
s1 = S()
print(id(s1))
s2 = S()
print(id(s2))

2159709448232
2159709448232

编程常用技巧:鸭子类型

简单来说,就是用不同的类给同一个变量赋值,这些类之间有同名的方法,用变量.方法调用时,变量是用哪个类的对象就调用哪个类里面的方法。这样可以优化程序,可读性也更高。

class Programer:
    def dowork(self):
        print("biancheng")
class Manger:
    def dowork(self):
        print("guanli")

employee = Manger()
employee.dowork()
employee = Programer()
employee.dowork()
上一篇下一篇

猜你喜欢

热点阅读