python-單例模式(四種實現方式)
一丶使用模組
python 的模組就是天然的單例模式,因為模組在第一次匯入時,會生成 .pyc 檔案,
當第二次匯入時,就會直接載入 .pyc 檔案,而不會再次執行模組**。因此,我們
只需把相關的函式和資料定義在乙個模組中,就可以獲得乙個單例物件了
#mysingleton.py
class mysingleton(object):
def foo(self):
pass
my_singleton = mysingleton()
'''from mysingleton import mysingleton
my_singleton.foo()
二丶使用__new__方法
class mysingleton2(object):
_instance = none
def __new__(cls,*args,**kwargs):
if not _instance:
cls._instance = super(mysingleton2,cls).__new__(cls,*args,**kwargs)
return cls._instance
class myclass1(mysingleton2):
a = 1
在上面的**中,我們將類的例項和乙個類變數 _instance 關聯起來,如果 cls._instance
為 none 則建立例項,否則直接返回 cls._instance。
三丶使用裝飾器
def decorator(cls,*args,**kwargs):
_instance = {}
def _decorator():
if cls not in _instance:
_instance[cls] = cls(*args,**kwargs)
return _instance[cls]
return _decorator
@decorator
class myclass2(object):
a = 1
在上面,我們定義了乙個裝飾器 decorator,它返回了乙個內部函式 _decorator,該函式會
判斷某個類是否在字典 _instance 中,如果不存在,則會將 cls 作為 key,cls(*args, **kw)
作為 value 存到 _instance 中,否則,直接返回 _instance[cls]。
四丶 使用 metaclass
元類(metaclass)可以控制類的建立過程,它主要做三件事:
攔截類的建立
修改類的定義
返回修改後的類
使用元類實現單例模式的**如下:
class single(type):
def __init__(cls,name,bases,adict):
super(single,cls).__init__(name,bases,adict)
cls._instance = none
def __call__(cls,*args,**kwargs):
if not cls._instance:
cls._instance = super(single,cls).__call__(*args,**kwargs)
return cls._instance
class myclass3(metaclass=singletons):
a = 1
python單例模式繼承 python單例模式
我們可以使用 new 這個特殊方法。該方法可以建立乙個其所在類的子類的物件。更可喜的是,我們的內建 object 基類實現了 new 方法,所以我們只需讓 sing 類繼承 object 類,就可以利用 object 的 new 方法來建立 sing 物件了。classsing object def...
單例模式 python
單例模式 保證乙個類僅有乙個例項,並提供乙個訪問它的全域性訪問點。實現 某個類只有乙個例項 途徑 1 讓乙個全域性變數使得乙個物件被訪問,但是它不能防止外部例項化多個物件。2 讓類自身負責儲存它的唯一例項。這個類可以保證沒有其他例項可以被建立。即單例模式。多執行緒時的單例模式 加鎖 雙重鎖定。餓漢式...
python單例模式
new 在 init 之前被呼叫,用於生成例項物件。利用這個方法和類的屬性的特點可以實現設計模式的單例模式。單例模式是指建立唯一物件,單例模式設計的類只能例項 例項化1個物件。class singleton object instance none def init self pass def ne...