__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