在 python 中,我們可以用多種方法來實現單例模式:
使用模組
其實,python 的模組就是天然的單例模式,因為模組在第一次匯入時,會生成.pyc
檔案,當第二次匯入時,就會直接載入.pyc
檔案,而不會再次執行模組**。因此,我們只需把相關的函式和資料定義在乙個模組中,就可以獲得乙個單例物件了。如果我們真的想要乙個單例類,可以考慮這樣做:
# mysingleton.py
class my_singleton(object):
def foo(self):
pass
my_singleton = my_singleton()
class singleton(object):
_instance = none
def __new__(cls, *args, **kw):
if not cls._instance:
cls._instance = super(singleton, cls).__new__(cls, *args, **kw)
return cls._instance
class myclass(singleton):
a = 1
在上面的**中,我們將類的例項和乙個類變數_instance
關聯起來,如果cls._instance
為 none 則建立例項,否則直接返回cls._instance
。
執**況如下:
>>> one = myclass()
>>> two = myclass()
>>> one == two
true
>>> one is two
true
>>> id(one), id(two)
(4303862608, 4303862608)
我們知道,裝飾器(decorator)可以動態地修改乙個類或函式的功能。這裡,我們也可以使用裝飾器來裝飾某個類,使其只能生成乙個例項,**如下:
from functools import wraps
def singleton(cls):
instances = {}
@wraps(cls)
def getinstance(*args, **kw):
if cls not in instances:
instances[cls] = cls(*args, **kw)
return instances[cls]
return getinstance
@singleton
class myclass(object):
a = 1
在上面,我們定義了乙個裝飾器singleton
,它返回了乙個內部函式getinstance
,該函式會判斷某個類是否在字典instances
中,如果不存在,則會將cls
作為 key,cls(*args, **kw)
作為 value 存到instances
中,否則,直接返回instances[cls]
。
元類(metaclass)可以控制類的建立過程,它主要做三件事:
使用元類實現單例模式的**如下:
class singleton(type):
_instances = {}
def __call__(cls, *args, **kwargs):
if cls not in cls._instances:
cls._instances[cls] = super(singleton, cls).__call__(*args, **kwargs)
return cls._instances[cls]
# python2
class myclass(object):
__metaclass__ = singleton
# python3
# class myclass(metaclass=singleton):
# pass
python中單例模式的實現
單例模式 保證系統中乙個類只有乙個例項而且該例項利於外界訪問。下面是python實現單例模式的一種方式。這裡用了重寫new方法來實現單例模式。在python中 new 方法是乙個靜態方法 它在物件被建立時呼叫,為物件分配空間,並且返回乙個位址傳給 init 方法 new 方法的第乙個引數是表示當前類...
在 Python 中實現單例模式
cyrusin.github.io 2015 09 15 python singleton 20150915 有些時候你的專案中難免需要一些全域性唯一的物件,這些物件大多是一些工具性的東西,在python中實現單例模式並不是什麼難事。以下總結幾種方法 使用類裝飾器 使用裝飾器實現單例類的時候,類本身...
python實現單例模式
最近在寫乙個連線池,而連線池管理類不可避免的需要使用單例來保證所有使用者在取得連線時取到的一定是同乙個管理物件。故將此模式取來研究一番。保證乙個類僅有乙個例項,並提供乙個訪問它的全域性訪問點 設計模式 單例模式是全域性只有乙個訪問點,故對於乙個類來說,任何例項化後訪問到的都應該是同樣的物件。而也有另...