一、总线
总线是计算机各种功能部件或者设备之间传送数据、控制信号等信息的公共通信解决方案之一。现假设有如下场景:某中央处理器(CPU)通过某种协议总线与一个信号灯相连,信号灯有64种颜色可以设置,中央处理器上运行着三个线程,都可以对这个信号灯进行控制,并且可以独立设置该信号灯的颜色。抽象掉协议细节(用打印表示),如何实现线程对信号等的控制逻辑。
加线程锁进行控制,无疑是最先想到的方法,但各个线程对锁的控制,无疑加大了模块之间的耦合。
什么是单例模式?单例模式是指:保证一个类仅有一个实例,并提供一个访问它的全局访问点。
具体到此例中,总线对象,就是一个单例,它仅有一个实例,各个线程对总线的访问只有一个全局访问点,即惟一的实例。
Python代码如下:
1 #encoding=utf8 2 import threading 3 import time 4 #这里使用方法__new__来实现单例模式 5 class Singleton(object):#抽象单例 6 def __new__(cls, *args, **kw): 7 if not hasattr(cls, '_instance'): 8 orig = super(Singleton, cls) 9 cls._instance = orig.__new__(cls, *args, **kw) 10 return cls._instance 11 #总线 12 class Bus(Singleton): 13 lock = threading.RLock() 14 def sendData(self,data): 15 self.lock.acquire() 16 time.sleep(3) 17 print "Sending Signal Data...",data 18 self.lock.release() 19 #线程对象,为更加说明单例的含义,这里将Bus对象实例化写在了run里 20 class VisitEntity(threading.Thread): 21 my_bus="" 22 name="" 23 def getName(self): 24 return self.name 25 def setName(self, name): 26 self.name=name 27 def run(self): 28 self.my_bus=Bus() 29 self.my_bus.sendData(self.name) 30 31 if __name__=="__main__": 32 for i in range(3): 33 print "Entity %d begin to run..."%i 34 my_entity=VisitEntity() 35 my_entity.setName("Entity_"+str(i)) 36 my_entity.start()
运行结果如下:
Entity 0 begin to run...
Entity 1 begin to run...
Entity 2 begin to run...
Sending Signal Data... Entity_0
Sending Signal Data... Entity_1
Sending Signal Data... Entity_2
在程序运行过程中,三个线程同时运行(运行结果的前三行先很快打印出来),而后分别占用总线资源(后三行每隔3秒打印一行)。虽然看上去总线Bus被实例化了三次,但实际上在内存里只有一个实例。
二、单例模式
单例模式是所有设计模式中比较简单的一类,其定义如下:保证某一个类只有一个实例,而且在全局只有一个访问点
三、单例模式的优点和应用
单例模式的优点:
1、由于单例模式要求在全局内只有一个实例,因而可以节省比较多的内存空间;
2、全局只有一个接入点,可以更好地进行数据同步控制,避免多重占用;
3、单例可长驻内存,减少系统开销。
单例模式的应用举例:
1、生成全局惟一的序列号;
2、访问全局复用的惟一资源,如磁盘、总线等;
3、单个对象占用的资源过多,如数据库等;
4、系统全局统一管理,如Windows下的Task Manager;
5、网站计数器。
四、单例模式的缺点
1、单例模式的扩展是比较困难的;
2、赋于了单例以太多的职责,某种程度上违反单一职责原则(六大原则后面会讲到);
3、单例模式是并发协作软件模块中需要最先完成的,因而其不利于测试;
4、单例模式在某种情况下会导致“资源瓶颈”。
归类 : Python--设计模式