在类的实例化中,每实例化一次,系统便给出一个内存地址用于保存实例,在需要大量实例化时就很占内存空间。使用单例模式就是为了节省内存空间。看下面一个小例子:
class Printer:
tasks = []
instance = None
def __init__(self,name):
self.name = name
def add_task(self,job): # 函数,打印任务,将变量job的参数或者实例加入空列表
self.tasks.append(job)
print('[%s]添加任务[%s]到打印机,总任务数[%s]' %(self.name,job,len(self.tasks)))
def __new__(cls,*args,**kwargs): #重写object方法
if cls.instance is None: #条件控制,为none时执行实例化,非none直接返回首次内存地址
#进行正常的实例化,并把实例化后的对象 存在cls.instance里.
obj = object.__new__(cls)
# 实例化过程。系统的方法,object.__new__(cls)实际上是为实例化建一个内存地址,其后是__init__方法来进行实例化填充实例。所以类的实例化其实有两部分,先是系统隐藏的__new__方法建一个内存地址,其次是__init__方法来初始化实例。
print('obj',obj)
cls.instance = obj #把实例化好的对象存下来
return cls.instance
# 以后的每次实例化,直接返回第一次存的实例对象在上一次实例对象的内存地址上,再执行__init__
p1 = Printer('Word app')
p2 = Printer('pdf app')
p3 = Printer('excel app')
p1.add_task('word file')
p2.add_task('pdf file')
p3.add_task('pexcel file')
print(p1,p2,p3)
print(p1.name,p2.name)
单例模式设计心得: 如果只希望执行第一次,那就设一个空变量,if 变量为none时执行操作,将结果赋值给空变量,然后函数返回该变量,就可以实现只执行第一次,因为后面该变量非none。