在 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 實現單例模式
encoding utf 8 print 方法1 方法1,實現 new 方法 並在將乙個類的例項繫結到類變數 instance上,如果cls.instance為none說明該類還沒有例項化過,例項化該類,並返回 如果cls.instance不為none,直接返回cls.instance class ...
python實現單例模式
單例模式,簡單來說,就是乙個類只能有乙個例項,並且能夠自行例項化向整個系統提供。例如檔案系統和任務管理器等。由此可見,單例模式的要點有三個 1.乙個類只能有乙個例項 2.它必須自行建立這個例項 3.它必須自行向整個系統提供這個例項 在python實現單例模式的方法總結起來有四種及其對應 如下 1.魔...