目錄單例模式(singleton pattern)是一種常用的軟體設計模式,該模式的主要目的是確保某乙個類只有乙個例項存在。當你希望在整個系統中,某個類只能出現乙個例項時,單例物件就能派上用場。
在 python 中,我們可以用多種方法來實現單例模式。
首先,我最推薦使用new方法來實現單例模式,因為我覺得這種方法是最容易理解的。我們知道new方法是類在例項化過程中呼叫的乙個方法,該方法還要在init方法之前呼叫,用於建立類的例項化物件。那麼我們是不是可以重寫new,讓他判斷是否已經呼叫過該方法了,如果已經呼叫過了,直接返回上次例項化的物件,那麼該類不就一直只存在乙個例項化物件了嗎,就實現了單例,例子如下。
class singleton(object):
def __new__(cls, *args, **kwargs):
if not hasattr(cls, '_instance'):
cls._instance = super(singleton, cls).__new__(cls, *args, **kwargs)
rerurn cls._instance
class a(singleton):
pass
# 類a即為單例類
我們可以寫乙個裝飾器,來裝飾我們需要指定的單例類,這樣也可以實現。
def singleton(cls):
instance = {}
if cls not in instance:
instance[cls] = cls(*args, **kwargs)
return instance[cls]
@singleton
class c:
pass
# 類c即為單例類
我們知道,在python中,我們可以自己寫乙個py檔案,裡面的類或者方法就可以通過模組匯入。在python中,用模組匯入的類就是乙個天然的單例。
# 作為python模組時是天然的單例模式
#建立乙個sington.py檔案,內容如下:
class singleton(object):
def foo(self):
pass
mysington = singleton()
# 運用
from sington import mysington
建立例項時把所有例項的dict指向同乙個字典,這樣它們都具有相同的屬性和方法(類的dict儲存物件屬性)
class singleton(object):
_state = {}
def __new__(cls, *args, **kwargs):
ob = super(singleton,cls).__new__(cls, *args, **kwargs)
ob.__dict__ = cls._state
return ob
class b(singleton):
pass
# 類b即為單例類
最後一種方法使用元類實現單例模式,這種方法比較不容易理解,首先需要理解元類是什麼,這裡就不展開細講了,有興趣的同學可以自行學習元類的用法。
class singleton(type):
_instacne = {}
def __call__(cls,*args,**kwargs):
if cls not in cls._instance:
cls._instances[cls] = super(singleton, cls).__call__(*args,**kwargs)
#以cls為key,cls(*args, **kwargs) 為值放入盛放單例的字典
return cls._instance[cls]
class myclass(metaclass=singleton):
pass
#myclass即為單例類
單例模式的實現方法大致就是以上幾種了 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...