python实现单例模式的三种方法
生活随笔
收集整理的這篇文章主要介紹了
python实现单例模式的三种方法
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
單例模式
單例模式(Singleton Pattern)是一種常用的軟件設計模式,該模式的主要目的是確保某一個類只有一個實例存在。當在整個系統中,某個類只能出現一個實例時,單例對象就能派上用場。
其目的就是令到單個進程中只存在一個類的實例,從而可以實現數據的共享,節省系統開銷,防止io阻塞等等
比如,某個服務器程序的配置信息存放在一個文件中,客戶端通過一個 AppConfig 的類來讀取配置文件的信息。如果在程序運行期間,有很多地方都需要使用配置文件的內容,也就是說,很多地方都需要創建 AppConfig 對象的實例,這就導致系統中存在多個 AppConfig 的實例對象,而這樣會嚴重浪費內存資源,尤其是在配置文件內容很多的情況下。事實上,類似 AppConfig 這樣的類,我們希望在程序運行期間只存在一個實例對象。
實現的三種方法:
方法1:
使用基類 New 是真正創建實例對象的方法,所以重寫基類的new 方法,以此保證創建對象的時候只生成一個實例
方法2:使用裝飾器
def singleton(cls):instances = {}def wrapper(*args, **kwargs):if cls not in instances:instances[cls] = cls(*args, **kwargs)return instances[cls]return wrapper@singleton class Foo(object):passfoo1 = Foo() foo2 = Foo() print(foo1 is foo2) # True方法3:元類,元類是用于創建類對象的類,類對象創建實例對象時一定要調用call方法,因此在調用call時候保證始終只創建一個實例即可,type是python的元類.
class Singleton(type):def __call__(cls, *args, **kwargs):if not hasattr(cls, '_instance'):cls._instance = super(Singleton, cls).__call__(*args, **kwargs)return cls._instanceclass Foo(metaclass=Singleton):passfoo1 = Foo() foo2 = Foo() print(foo1 is foo2) # True學習整理轉載自:https://github.com/kenwoodjw/python_interview_question#
總結
以上是生活随笔為你收集整理的python实现单例模式的三种方法的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: Python实现遍历目录与子目录,并找到
- 下一篇: Python中变量的作用域?(变量查找顺