__new__方法是构建对象的方法,__init__方法是初始化对象的方法。
概念:确保某一个类只有一个实例,而且自行实例化并向整个系统提供这个实例,这个类称为单例类,单例模式是一种对象创建型模式。
目的:单个进程中只存在一个类的实例,从而实现数据共享,节省系统开销,防止IO阻塞
方法1:使用模块创建单例:
文件card.py:
#coding:utf-8
class Card(object):
def __init__(self,user,passed):
self.user= user
self.passwd =passed
c= Card('zhang','1234')
文件main.py:
#coding:utf-8
'''
原理:python的模块是天然的单例模式,因为模块在第一次到导入时会产生pyc文件,
但第二次导入会直接加载pyc文件,而不会再执行模块代码
'''
from .card import c
方法2:使用__new__()创建单例:
#coding:utf-8
class Singleton(object):
'''
Desc:单例模式,只要把下面紫色部分复制到类中,该类就会变成单例类
原理:一个类创建对象实例是通过调用object的__new__(cls)方法,那可以重写__new__(cls)方法实现单例
'''
def __new__(cls, *args, **kw): #cls表示Singleton类
#每一次实例化都返回instance同一对象
if not hasattr(cls, u'_instance'):
cls._instance = super(Singleton, cls).__new__(cls)
return cls._instance
a=Singleton()
b=Singleton()
print(id(a),id(b)) #34034856 34034856
print(a is b) #Truea
方法3:使用装饰器实现单例:
#coding:utf-8
def singleton(cls): #cls表示类
instances ={}
def getinstance(*args,**kwargs):
if cls not in instances:
instances[cls] = cls(*args,**kwargs) #类的对象
return instances[cls]
return getinstance
@singleton
class Card(object):
pass
@singleton
class Persion(object):
pass
c1=Card()
c2=Card()
print(c1 is c2) #True
p1=Persion()
p2=Persion()
print(p1 is p2) #True